0

我正在尝试让 NODE-ORM2 扩展工作。我找不到要遵循的全包示例,只有一些从模型定义级别开始的部分示例(不参考数据库)。

本质上,我有两个模型 A 和 B,它们之间存在一对一的关系,其中 B.AId 是 A.id 的外键(为简单起见,我可能应该在 db 语句中确定这一点,但 orm2 没有读取这些关系。

我不明白它为什么要寻找 a_b 关系表。我也不明白如何形成两个模型之间的关系。

有人可以帮忙吗?在 hasOne 关系中,我们可以指定字段 - 这里似乎缺少。

D B:

create table A
(
  `id` int(11) NOT NULL AUTO_INCREMENT key,
  `addedOn` date DEFAULT NULL
) ENGINE=InnoDB AUTO_INCREMENT=1718087 DEFAULT CHARSET=utf8;

create table B
(
  `id` int(11) NOT NULL AUTO_INCREMENT KEY,
  AId int(11),
  `addedOn` date DEFAULT NULL
) ENGINE=InnoDB AUTO_INCREMENT=1718087 DEFAULT CHARSET=utf8;

insert into A (addedOn)values('2012-02-02')
insert into B (AId, addedOn)values((select id from A), '2012-02-04')

楷模:

// User Model
module.exports = function (db, cb) {
    console.log('ORM loading \'A\' model')

    var A = db.define('A', {
        id              : Number,
        addedOn         : Date
    }) ;

    var B = A.extendsTo('B', {
        id              : Number,
        AId             : Number,
        addedOn         : Date
    })
    return cb()
}

恢复:

    var A = req.db.models.A
    A.get(1718087, {autoFetch: true}, function(err, a){
        a.getB(function(err,  b){
            console.log(JSON.stringify(b, null, 4))
        })

        console.log(JSON.stringify(a, null, 4))
    })

例外:

ER_NO_SUCH_TABLE: Table 'mydb.a_b' doesn't exist
4

1 回答 1

0

我可以通过在模型定义中指定表名和外键来解决这个问题:

var A = db.define('A', {
    id              : Number,
    addedOn         : Date
}) ;

var B = A.extendsTo('B', {
    id              : Number,
    AId             : Number,
    addedOn         : Date
}, {field: 'AId', table: 'B'})

让我们看看 Extend.js 内部的一些原因:

 exports.prepare = function (db, Model, associations, association_properties, model_fields) {
Model.extendsTo = function (name, properties, opts) {
    opts = opts || {};

    var assocName = opts.name || ucfirst(name);
    var association = {
        name           : name,
        table          : opts.table || (Model.table + '_' + name),

        field          : util.wrapFieldObject(opts.field, Model, Model.table, Model.properties) || util.formatField(Model, Model.table, false, false),
        getAccessor    : opts.getAccessor || ("get" + assocName),
        setAccessor    : opts.setAccessor || ("set" + assocName),
        hasAccessor    : opts.hasAccessor || ("has" + assocName),
        delAccessor    : opts.delAccessor || ("remove" + assocName)
    };

然后是 util.formatField:

        association_key : "{name}_{field}",

因此,除非指定,否则它假定该表是连接到模型名称的主表。外键是 primary_table 与 field 参数连接。

在我的例子中,在没有指定表和字段的情况下,node-orm 代码正在寻找具有外键 A_id 的表 A_B。

于 2014-05-02T18:34:54.723 回答