我正在尝试让 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