Sequelize 连接两个不相关的表

Mop*_*ath 6 mysql node.js sequelize.js

我试图通过使用关系连接两个未“关联”的表来检索数据。这两个表如下:

mysql> desc partner_txns;
+------------+-------------+------+-----+---------+----------------+
| Field      | Type        | Null | Key | Default | Extra          |
+------------+-------------+------+-----+---------+----------------+
| id         | int(11)     | NO   | PRI | NULL    | auto_increment |
| txn_id     | int(11)     | NO   |     | NULL    |                |
| user_id    | int(11)     | NO   | MUL | NULL    |                |
| txn_type   | varchar(1)  | YES  |     | NULL    |                |
| txn_amnt   | double      | YES  |     | NULL    |                |
| desc       | varchar(64) | YES  |     | NULL    |                |
| createdBy  | int(11)     | NO   | MUL | NULL    |                |
| created_on | datetime    | NO   |     | NULL    |                |
+------------+-------------+------+-----+---------+----------------+
8 rows in set (0.00 sec)

mysql> desc accounts_master;
+-------------+-------------+------+-----+---------+----------------+
| Field       | Type        | Null | Key | Default | Extra          |
+-------------+-------------+------+-----+---------+----------------+
| id          | int(11)     | NO   | PRI | NULL    | auto_increment |
| name        | varchar(64) | NO   |     | NULL    |                |
| owner       | int(11)     | NO   | MUL | NULL    |                |
| type        | int(11)     | YES  |     | 0       |                |
| expires_on  | datetime    | NO   |     | NULL    |                |
| max_lists   | int(11)     | YES  |     | 10      |                |
| max_groups  | int(11)     | YES  |     | 10      |                |
| createdBy   | int(11)     | NO   | MUL | NULL    |                |
| modifiedBy  | int(11)     | NO   | MUL | NULL    |                |
| created_on  | datetime    | NO   |     | NULL    |                |
| modified_on | datetime    | NO   |     | NULL    |                |
+-------------+-------------+------+-----+---------+----------------+
11 rows in set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)

在不使用 sequelize 的情况下,通常我会进行这样的 SQL 查询:

mysql> select a.user_id, b.name from partner_txns a, accounts_master b where a.createdBy = 3 and a.user_id = b.owner;
+---------+-------------+
| user_id | name        |
+---------+-------------+
|       8 | New account |
|       8 | Comviva     |
|       8 | Infosys     |
|       9 | HDFC        |
|       9 | INTEGRA     |
+---------+-------------+
5 rows in set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)

使用 Sequelize 执行此操作的等价物是什么,假设我将这两个表作为两个模型,如下所示:

  • 合作伙伴发送
  • 帐户

我很想使用像:

var Model = require('ecp_model');

Model.PartnerTxn.findAll({
  where: {createdBy:3 },
  include : [{model:Model.Account, attribute:['name']}]
}).then(function(results) {
   console.log("results:", results);
});
[rv.nath@localhost authserver]$ 
Run Code Online (Sandbox Code Playgroud)

但是这将不起作用,因为这两个表不相关。所以,我收到如下错误:

Unhandled rejection Error: Account is not associated to PartnerTxn!
    at validateIncludedElement (/var/opt/ecp_db/node_modules/sequelize/lib/model.js:569:11)
    at /var/opt/ecp_db/node_modules/sequelize/lib/model.js:452:29
    at Array.map (native)
    at validateIncludedElements (/var/opt/ecp_db/node_modules/sequelize/lib/model.js:448:37)
    at null.<anonymous> (/var/opt/ecp_db/node_modules/sequelize/lib/model.js:1360:32)
    at tryCatcher (/var/opt/ecp_db/node_modules/bluebird/js/release/util.js:16:23)
    at Promise._settlePromiseFromHandler (/var/opt/ecp_db/node_modules/bluebird/js/release/promise.js:503:31)
    at Promise._settlePromise (/var/opt/ecp_db/node_modules/bluebird/js/release/promise.js:560:18)
    at Promise._settlePromise0 (/var/opt/ecp_db/node_modules/bluebird/js/release/promise.js:605:10)
    at Promise._settlePromises (/var/opt/ecp_db/node_modules/bluebird/js/release/promise.js:684:18)
    at Async._drainQueue (/var/opt/ecp_db/node_modules/bluebird/js/release/async.js:126:16)
    at Async._drainQueues (/var/opt/ecp_db/node_modules/bluebird/js/release/async.js:136:10)
    at Immediate.Async.drainQueues [as _onImmediate] (/var/opt/ecp_db/node_modules/bluebird/js/release/async.js:16:14)
    at processImmediate [as _immediateCallback] (timers.js:383:17)
Run Code Online (Sandbox Code Playgroud)

小智 2

我知道这已经是差不多一年后的事了,但以防万一有人处于你的情况并正在寻找正确的答案。

当您有由第三个表链接的两种单独的数据类型时,您正在寻找 Sequelize 的 BelongToMany(Through)。

因此,在您的情况下,您需要定义第三个模型:UserMaster。您将为 UserMaster 提供两个属性:user_id(与 PartnerTxn 属性相同)和所有者(与 Account 属性相同)。

然后你会这样做:

Account.belongsToMany(PartnerTxn, {through: 'UserMaster'});
PartnerTxn.belongsToMany(Account, {through: 'UserMaster'});
Run Code Online (Sandbox Code Playgroud)

为了进一步参考,文档中有信息。

  • 如果两个表没有逻辑关联,但您只想获取单个查询的结果怎么办?就问题而言,没有迹象表明这两个表应该通过第三个表关联,并且我认为仅仅为了在单个续集中获取结果而添加第三个表不是一个好主意询问。 (9认同)