我在mysql数据库中有一个语言标签,其中我有一个自动递增的Id:
CREATE TABLE `languages` (
`Id` int(11) NOT NULL AUTO_INCREMENT,
`Language` varchar(45) NOT NULL,
PRIMARY KEY (`Id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
当我运行sequelize-auto命令时:
sequelize-auto -h 127.0.0.1 -d DBNAME -u root -x PASSWORD -p 3306 --dialect mysql -c MYPATH\json/sequelize-auto-settings.json -o MODELSPATH\src\assets\models
我得到以下modeL:
/* jshint indent: 1 */
module.exports = function(sequelize, DataTypes) {
return sequelize.define('languages', {
Id: {
type: DataTypes.INTEGER(11),
allowNull: false,
primaryKey: true,
field: 'Id'
},
Language: {
type: DataTypes.STRING(45),
allowNull: false,
field: 'Language'
}
}, {
tableName: 'languages'
});
};
为什么Id字段中缺少autoincrment : true
?
我可以手动添加它,但它违背了使用sequelize -auto的目的
发布于 2020-04-23 02:11:01
这花了一些时间,我可以坦率地说,我仍然不知道问题出在哪里。
我通过安装 sequelize-auto v3 解决了它,然后它就像预期的那样工作了。
https://stackoverflow.com/questions/61362055
复制相似问题