node.js - 在 Sequelize 中创建关联以进行左连接

标签 node.js postgresql sequelize.js

我想使用 Sequelize 进行左连接,其作用与此 SQL 代码相同。

从事件 LEFT JOIN 区域中选择 * on event_tz=zid WHERE event_creator_fk=116;

我有两个表:eventszones(带有时区列表)。

在查询特定用户创建的所有事件时,我还想获取时区名称以及有关 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/

相关文章:

node.js - socket.io 连接上的多次握手

sql - 在 SQL 中使用位串(而不是整数)匹配位掩码

postgresql - 从postgresql中的多个sql查询输出结果

postgresql - bcrypt compareSync “Unhandled rejection Error: data and hash must be strings”

javascript - Sequelize迁移错误: Cannot read property 'length' of undefined

Node.JS:重用套接字?

node.js - 在 Meteor 1.0 中加载 NPM 包?

javascript - pg-promise helpers.update 不工作

node.js - Sequelize 唯一约束错误: Validation error

express - Sequelize Express 多个模型