[报错解决]SequelizeDatabaseError: Unknown column ‘created_at‘ in ‘field list‘

sequelize 报错
SequelizeDatabaseError: Unknown column ‘created_at’ in ‘field list’
或者
Sequelize Unknown column ‘createdAt’ in ‘field list’?
SequelizeDatabaseError: Unknown column 'created_at' in 'field list'
    at Query.formatError (D:\***\express\node_modules\_sequelize@6.3.5@sequelize\lib\dialects\mysql\query.js:239:16)
    at Query.run (D:\***\express\node_modules\_sequelize@6.3.5@sequelize\lib\dialects\mysql\query.js:54:18)
    at process._tickCallback (internal/process/next_tick.js:68:7)
SequelizeDatabaseError: Unknown column 'created_at' in 'field list'
    at Query.formatError (D:\***\express\node_modules\_sequelize@6.3.5@sequelize\lib\dialects\mysql\query.js:239:16)
    at Query.run (D:\***\express\node_modules\_sequelize@6.3.5@sequelize\lib\dialects\mysql\query.js:54:18)
    at process._tickCallback (internal/process/next_tick.js:68:7)
报错原因:

在sequelize中启用了时间戳(即sequelize中创建的model开启了时间戳),但是在数据库中的实际表定义不包含时间戳列。

当你做model.findAll时,会将model中的每一进行别名查询(也包括model中开启的时间戳),从而创建下面例子查询,这面就包含了数据库中实际没有的时间戳列(createdAt,updatedAt)

解决办法

在model创建的时候禁用时间戳,例如禁用mysql 表模型的时间戳
在最后加上 timestamps: false,

/* jshint indent: 2 */

module.exports = function(sequelize, DataTypes) {
  return sequelize.define('sunny_sorturl', {
    id: {
      type: DataTypes.BIGINT,
      allowNull: false,
      primaryKey: true,
      comment: '主键'
    },
    describe: {
      type: DataTypes.STRING(255),
      allowNull: true,
      comment: '描述'
    }
  }, {
    sequelize,
    timestamps: false,
    tableName: 'sunny_sorturl'
  });
};

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值