首页 >web前端 >js教程 >为什么 Sequelize 不总是创建外键列,如何解决此问题?

为什么 Sequelize 不总是创建外键列,如何解决此问题?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-09 08:48:07578浏览

Why Doesn't Sequelize Always Create Foreign Key Columns, and How Can I Fix This?

为什么 Sequelize 不为某些模型创建外键列?

Sequelize 通常在使用 ownTo() 关联时为外键创建一个新列。但是,在某些情况下,它可能不会这样做。

理解问题

提供的 User 模型中描述了一个这样的场景,其中 Sequelize 无法创建 role_id 列。这会引起担忧和困惑,特别是当同一项目中的其他模型表现出预期行为时。

解决方案:集中模型注册

解决方案在于集中注册所有模型及其关联一个地方。这确保 Sequelize 可以在模型之间建立正确的关系。

实现

  1. 创建单个文件 database.js 来处理模型注册。
  2. 导入所有models 目录中的模型文件。
  3. 为每个模型调用 Associate() 函数来定义模型之间的关系
// database.js
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const db = {};

const sequelize = new Sequelize(/* your connection settings here */);
const models = path.join(__dirname, 'models');

fs.readdirSync(models).filter(file => file.indexOf('.') !== 0 && file !== 'basename' && file.slice(-3) === '.js').forEach(file => {
  const model = sequelize['import'](path.join(models, 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;
  1. 在其他模块中,导入 db 对象并通过它访问模型和关联。
// some_module.js
const db = require('../database');

const users = await db.user.findAll({
  where: {
    [db.Sequelize.Op.or]: [{
      first_name: 'Smith'
    }, {
      last_name: 'Smith'
    }]
   }
});

按照以下步骤,您可以确保所有模型都正确注册,并且正确建立它们的关联,从而允许 Sequelize 为外键创建必要的列。

以上是为什么 Sequelize 不总是创建外键列,如何解决此问题?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn