javascript - 在没有模型 :generate? 的情况下在 Sequelize 中创建新模型

标签 javascript node.js express sequelize.js

如果我通过复制粘贴制作模型可以吗?例如,我通过 Sequelize 的 User 制作了我的第一个模型 model:generate 。然后对于其他模型,我只是将 User 模型中的所有内容复制粘贴到我的新模型中。

进行数据库同步时:

db.sequelize.sync({ force : true}).then(() => {
  console.log("Drop and re-sync db.")
})

新模型不会创建新表。所以我认为新模型的复制粘贴行不通。这是正确的吗?

用户模型:
'use strict';
module.exports = (sequelize, DataTypes) => {
  const User = sequelize.define('User', {
    id: { type: DataTypes.BIGINT, allowNull: false, unique: true, primaryKey: true },
    fbid: { type: DataTypes.BIGINT, allowNull: false, unique: true },
    email: DataTypes.STRING,
    first_name: DataTypes.STRING,
    last_name: DataTypes.STRING,
    photo_url: DataTypes.STRING
  }, {});
  User.associate = function(models) {
    // associations can be defined here
  };
  return User;
};

并从复制粘贴+修改用户模型生成,我有: Country 模型
'use strict';
module.exports = (sequelize, DataTypes) => {
  const Country = sequelize.define('Country', {
    country_name: DataTypes.STRING
  }, {});
  Country.associate = function(models) {
    // associations can be defined here
  };
  return Country;
};

Index.js 由我的模型中的 cli 生成:
'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')[env];
const db = {};

let sequelize;
if (config.use_env_variable) {
  sequelize = new Sequelize(process.env[config.use_env_variable], config);
} else {
  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;

然后在生成模型之后,在执行 model:generate 之后,我将生成的 User.js 转移到一个 User 文件夹中。然后进行复制粘贴,不确定移动文件是否会影响我通过复制粘贴创建的模型的注册。

enter image description here

最佳答案

根据上面的评论,我意识到我的 index.js 文件(由 Sequelize 生成)并不是在寻找放置在子文件夹中的模型文件。相反,它只查找根文件夹中的模型文件 - index.js 文件的同一级别。

所以我发布了这个问题:Javascript get all files in a folder that are inside another fold

我不得不使用包 glob 使 index.js 文件也查找子文件夹。

所以我的 index.js 的内容现在是:

'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')[env];
const db = {};
const glob = require("glob")

let sequelize;
if (config.use_env_variable) {
  sequelize = new Sequelize(process.env[config.use_env_variable], config);
} else {
  sequelize = new Sequelize(config.database, config.username, config.password, config);
}

const files = glob.sync(__dirname + "/*/*.js")

files.forEach(file => {
  const model = sequelize['import'](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;

要回答具体问题,否。我不必一直执行命令。我可以复制粘贴编辑新模型。

关于javascript - 在没有模型 :generate? 的情况下在 Sequelize 中创建新模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61644538/

相关文章:

javascript - 在运行时添加路由 (ExpressJs)

javascript - 如何在 Mongoose 中找到 "By Name"

javascript - 返回前从多个 HTTP GET 请求获取数据

javascript - 将点击事件绑定(bind)到点击

node.js - 匹配 Mongoose 数组中指定的所有值

javascript - Electron.js错误 “require”没有在index.html的<script>标记中定义

node.js - 类型错误 : Cannot read property 'connect' of undefined

Javascript 函数立即停止

javascript - 表格行插入到错误的位置

javascript - 使用node.js ejsexpress显示mysql查询结果