我想使用 Sequelize 进行左连接,其作用与此 SQL 代码相同。
从事件 LEFT JOIN 区域中选择 * on event_tz=zid WHERE event_creator_fk=116;
我有两个表:events
和 zones
(带有时区列表)。
在查询特定用户创建的所有事件时,我还想获取时区名称以及有关 TZ 的其他详细信息。
我通过查看示例代码、其他 Stack Overflow 问题和文档,尝试了多种解决方案组合。该查询始终有效,但不执行任何联接。也就是说,下面的代码始终返回事件列表,但不返回 zones
表中的时区数据。生成的 SQL 是正确的,只是它没有 ...LEFT JOIN zone ON event_tz=zid...
部分。
下面的代码是错误的。详情请参阅答案。
db.Event.findAll(
{ where: { event_creator_fk: someUserID } },
{ include: [{ model: db.Zone } ]}
);
如果我理解正确的话,在 Sequelize 中添加表之间的关联会导致自动创建一个附加列。这不是我想做的。我不希望 Sequelize 以任何方式修改表或数据库。我想设置我的数据库及其表而不使用 Sequelize。因此,我没有调用 sequelize.sync()
。我不知道是否可以按照我想要的方式设置关联。
模型定义
module.exports = function (sequelize, DataTypes) {
var Event = sequelize.define('Event', {
eid: {
type: DataTypes.INTEGER,
primaryKey: true
},
event_tz: {
type: DataTypes.INTEGER,
primaryKey: true,
references: "Zone",
referencesKey: "zid"
},
}, {
classMethods: {
associate: function (models) {
return models.Event.hasOne(models.Zone);
}
},
freezeTableName: true,
timestamps: false,
tableName: 'events'
}
);
return Event;
};
module.exports = function (sequelize, DataTypes) {
return sequelize.define('Zone', {
zid: {
type: DataTypes.INTEGER,
primaryKey: true
}
}, {
classMethods: {
associate: function (models) {
return models.Zone.belongsTo(models.Event);
}
},
freezeTableName: true,
timestamps: false,
tableName: 'zones'
});
};
表格定义
DROP TABLE IF EXISTS zones;
CREATE TABLE IF NOT EXISTS zones (
zid integer NOT NULL,
country_code character(2) NOT NULL,
zone_name text NOT NULL,
PRIMARY KEY (zid)
);
DROP TABLE IF EXISTS events;
CREATE TABLE IF NOT EXISTS events (
eid BIGSERIAL NOT NULL,
event_tz SERIAL NOT NULL,
PRIMARY KEY (eid),
FOREIGN KEY (event_tz)
REFERENCES zones(zid) MATCH FULL ON DELETE RESTRICT
);
最佳答案
您需要反转关联并告诉sequelize您的外键。 belongsTo 表示“将 fk 添加到此模型”:
models.Event.belongsTo(models.Zone, { foreignKey: 'event_tz');
models.Zone.hasOne(models.Event, { foreignKey: 'event_tz');
// or hasMany if this is 1:m
关于node.js - 在 Sequelize 中创建关联以进行左连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30157905/