我正在为社交网站创建一个配置文件系统。我使用关系很难显示有关用户来自不同表的各种信息。这是我的两个Bookshelfjs模型:
房间:
var user = require(__base + '/app/database/models/user/user').model;
exports.model = Application.Adapter.Model.extend({
tableName: 'rooms',
hasTimestamps: false,
owner: function() { return this.hasOne(user, 'id', 'owner_id'); }
});
用户:
var user_badges = require(__base + '/app/database/models/user/user_badges').model,
user_settings = require(__base + '/app/database/models/user/user_settings').model,
rooms = require(__base + '/app/database/models/room/room').model,
groups = require(__base + '/app/database/models/group/group').model;
exports.model = Application.Adapter.Model.extend({
tableName: 'users',
hasTimestamps: false,
badges: function() { return this.hasMany(user_badges, 'user_id', 'id'); },
settings: function() { return this.hasMany(user_settings, 'user_id', 'id'); },
rooms: function() { return this.hasMany(rooms, 'owner_id', 'id'); },
groups: function() { return this.hasMany(groups, 'user_id', 'id'); }
});
这两个模型均在不同页面上完全分开。我目前正在使用个人资料页面上的用户模型中的所有关系,并且这些关系正在工作。我有一个不同的页面,该页面将显示有关房间的所有信息以及所有者信息。这是我到目前为止使用房间模型的方式
var room = require(__base + '/app/database/models/room/room').model;
var room_id = 1;
return new room({id: room_id}).fetch({
withRelated: [
{'owner': function(qb) {
qb.column('id','username');
}}
],
columns: ['id', 'owner_id', 'name']
})
.then(function resolve(result)
{
if(result == null) return Promise.reject(new Error('invalid_room'));
return Promise.resolve(result.toJSON());
},
function reject(err)
{
return Promise.reject(err);
});
这是我收到的错误:
A valid target model must be defined for the rooms hasOne relation
我尝试使用hasone&属于属于,但似乎无法实现,如果有人有解决方案,请告诉我谢谢!
当循环引用不可避免(通常为)时,注册表插件可能会帮助您进行更简单的设置。
在您的情况下,Application.Adapter
看起来像是书架的实例,因此,如果将注册表插件添加到其中(使用Application.Adapter.plugin('registry')
),您的room
类应该看起来像:
// Take references from the registry instead of using `require`
// Note: assuming 'user' was registered with registry plugin
var user = Application.Adapter.model('user');
var room = Application.Adapter.Model.extend({
tableName: 'rooms',
hasTimestamps: false,
// Note the use of 'user' instead of user
owner: function() { return this.hasOne('user', 'id', 'owner_id'); }
});
// Model modules no longer needed to be exported, just registered
Application.Adapter.model('room', room);
注意在上面的示例中,无需从注册表中获取user
,因为它从未直接用作模型。但是我将其保留为如何从注册表中获取模型。