我试图通过列名SequelizeSequelize顺序按列名
这里订购是我的模型
var Milestones = sequelize.define('milestones', {
milestoneId: Sequelize.INTEGER,
data: Sequelize.JSON,
repository: Sequelize.STRING
});
数据库是PostegreSql 9.5
var dialect = 'postgres',
protocol = 'postgres';
var sequelize = new Sequelize(dbConfig.database, dbConfig.user, dbConfig.password, {
host: dbConfig.host,
dialect: dialect,
protocol: protocol,
dialectOptions: {
timeout: 30
},
pool: {
max: 5,
min: 0,
idle: 30000,
maxConnections: 5,
maxIdleTime: 30
},
logging: false
});
这里是我的查询
models.Milestones.findAll({
where: {
repository: req.body.repository
},
order: 'milestoneId'
}).then(function (values) {
// do something
});
这是我的错误
Unhandled rejection SequelizeDatabaseError: column "milestoneid" does not exist
所以问题是,我通过milestoneId
想秩序,但Sequelize实际上是试图通过milestoneid
订购(注意缺乏骆驼情况下)。
如果我更改为订购repository
一切正常,所以此问题似乎与Sequelize转换为小写字母有关。
除了将数据库中的列重命名为小写以外的任何建议?
谢谢
这应该是工作,也应该是'milestoneId',而不是'milestonesId' – tyler
字段实际上没有发挥作用,但改变顺序做了诀窍 –