format - 如何使 sequalize createTable 支持下划线?
问题描述
我试图使用 sequalize seed 来初始化表行,但我得到了错误返回:
关系“用户”的“createdAt”列不存在
它实际上是“created_at”作为字段,所以我的问题是如何使用蛇或下划线选项为表格播种?
我的种子代码如下:
"use strict";
module.exports = {
up: (queryInterface, Sequelize) => {
return queryInterface.bulkInsert(
"users",
[
{
firstname: "John",
lastname: "Doe",
email: "demo@demo.com",
createdAt: new Date(),
updatedAt: new Date()
}
],
{}
);
},
down: (queryInterface, Sequelize) => {
return queryInterface.bulkDelete("users", null, {});
}
};
解决方案
您在定义数据库连接配置时传递这些信息,如下所示。
'use strict';
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(__filename);
const env = process.env.NODE_ENV || 'development';
const config = require(__dirname + '/../config/config.json')[env];
const db = {};
let sequelize;
if (config.use_env_variable) {
sequelize = new Sequelize(process.env[config.use_env_variable], config);
} else {
config.define = {
"timestamps":true,
"createdAt":"created_at",
"updatedAt":"updated_at"
}
sequelize = new Sequelize(config.database, config.username, config.password,config );
}
fs
.readdirSync(__dirname)
.filter(file => {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(file => {
const model = sequelize['import'](path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
这config
是您的数据库配置。您将其他配置添加到单独的define
推荐阅读
- azure - 通过 Powershell 脚本检查具有不同资源的已停止 VM
- python - Python os.system cp 命令复制空文件
- java - 无法从 java.text.ParseException 行解析日期:无法解析的日期
- php - 为什么结果等于 0 有时等于 1 - shell_exec('pgrep -f
- jasmine - 如何获取规范名称以用作量角器-html-reporter-2 中的输出文件名?
- android - 启用 GPS 定位后,AlertDialog 没有被禁用
- html - 设置可滚动的背景图片
- extjs6-classic - 将新对象添加到网格
- java - 只有一列,如何在 mysql 中为 A 一对多 B 设计关系
- mysql - 仅当两条或多条记录具有相同值时才连接两个表并进行分组