1

我正在为我的模型创建一个测试,现在我的场景是我想插入到一个表中,其中的列/字段未在我的Sequelize模式中定义。

这是我的架构示例

class ResploginSchema extends Sequelize.Model { }
ResploginSchema.init(
    {
        resploginID: {
            type: Sequelize.BIGINT(20).UNSIGNED,
            autoIncrement: true,
            primaryKey: true,
            allowNull: false
        },
        clientID: {
            type: Sequelize.INTEGER(10).UNSIGNED,
            allowNull: false,
            validate: {
                isNumeric: true
            }
        },
        tablelimitID: {
            type: Sequelize.TINYINT(2).UNSIGNED,
            allowNull: false
        },
        errMsgID: {
            type: Sequelize.INTEGER(6).UNSIGNED,
            allowNull: false
        }
    },
    {
        sequelize: dbConnection,
        modelName: "resplogin",
        freezeTableName: true,
        timestamps: false
    }
);

这是我要插入的示例数据

let data = {
            clientID: 1,
            sessionID: "not defined field",
            tablelimitID: 1,
            errMsgID: 0
        };


ResploginSchema.create(data)

我期待它应该返回一个错误,指出模型定义中没有定义sessionID 。

也许我错过了模型上的一些配置。提前致谢

续集版本:5.21.3

节点版本:10.14.2

4

1 回答 1

0

这是预期的行为。Sequelize 只会尝试在它不关心的模式中查找是否有其他字段的字段。事实上,在很多情况下,您可能需要未存储在数据库中的虚拟字段,但您可以在业务逻辑中使用。

于 2020-02-09T09:06:11.133 回答