0

我发现了很多关于关联的东西,但对我的特殊情况却一无所获,
我创建了一些模型并试图将它们关联起来,
所以我认为这也是理解数据库建模的问题。

我有模型用户和员工,它们都共享一个属性 user_id。

用户.js

'use strict';
module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define('User', {
    user_id: DataTypes.STRING,
    fullname: DataTypes.STRING,
    username: DataTypes.STRING,
    comment: DataTypes.TEXT
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
        User.hasMany(models.Sshkey, {foreignKey: 'sshkey_id'})
      }
    }
  });
  return User;
};

员工.js

'use strict';
module.exports = function(sequelize, DataTypes) {
  var Staff = sequelize.define('Staff', {
    user_id: DataTypes.STRING,
    fullname: DataTypes.STRING,
    username: DataTypes.STRING,
    password: DataTypes.STRING,
    isAdmin: DataTypes.BOOLEAN
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
        Staff.hasMany(models.Sshkey, {foreignKey: 'sshkey_id'})
      }
    }
  });
  return Staff;
};

我有一个模型 sshkey,它可以属于用户或工作人员。
我正在使用 Sequelize cli,但尚未进行任何迁移。
而且我对 Js 和创建数据库非常陌生,考虑数据库模型和关联,如果我能写或做这样的事情,我很好奇:

'use strict';
module.exports = function(sequelize, DataTypes) {
  var Sshkey = sequelize.define('Sshkey', {
    sshkey_id: DataTypes.STRING,
    sshkey: DataTypes.TEXT
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here

        // My Problem starts here |
        // Should i write         |
        //                        |
        //                        V

        Sshkey.hasOne(models.User || models.Staff, {foreignKey: 'user_id'})

        // Or maybe:
        // Sshkey.hasOne(models.User, {foreignKey: 'user_id'}) ||
        // Sshkey.hasOne(models.Staff, {foreignKey: 'user_id'})
        // Should i rather rename models.Staffs foreignKey user_id to staff_id?

        // Or maybe:
        // Sshkey.hasOne(models.User, {as: 'userkey', foreignKey: 'user_id'})
        // Sshkey.hasOne(models.Staff, {as: 'staffkey', foreignKey: 'user_id'})

      }
    }
  });
  return Sshkey;
};

如果我以后想将 sshkey 引用给用户或工作人员,那么该问题的正确解决方案是什么?
使用人员密钥和用户密钥制作两个模型?
提前致谢,

大Z

4

1 回答 1

1

如果您想要将外键user_id添加到Sshkey模型中的 1:m 关系,则应为:

User.hasMany(models.Sshkey, {foreignKey: 'user_id'});
Staff.hasMany(models.Sshkey, {foreignKey: 'user_id'});
Sshkey.belongsTo(models.User, {foreignKey: 'user_id'});
Sshkey.belongsTo(models.Staff, {foreignKey: 'user_id'});

我在您的示例中遇到的一个问题是,user_id它们sshkey_id都是没有约束的字符串,这使得它们非常糟糕foreignKey,并且对于设计数据库来说很糟糕。要获取用户及其 Sshkey:

User.findAll({
  where: {},
  include: [ { model: Sshkey } ]
});
于 2017-01-03T16:19:13.787 回答