bookshelf.js关系hasMany错误

时间:2014-11-18 15:34:53

标签: javascript node.js relationship bookshelf.js

我使用Bookshelf在hasMany电话上收到以下错误:

 A valid target model must be defined for the roles hasMany relation

Role.js

var Data = require('../server-includes/Data'),
    User = require('./User');

var Role = Data.bookshelf.Model.extend({
  tableName: 'roles',
  users: function() {
    return this.hasMany(User, 'role_id');
  }
});

module.exports = Role;

user.js的

var Data = require('../server-includes/Data'),
    Role = require('./Role');

var User = Data.bookshelf.Model.extend({ 
  tableName: 'users',
  role: function() {
    return this.belongsTo(Role, 'id');
  },
};

module.exports = User;

用法:

new Role({ id: req.params.id })
.fetch({ require: true, withRelated:['users'] })
.then(function (role) {
  role.users().fetch().then(function(users) {
    console.log('users: ' + users);
  });
})

2 个答案:

答案 0 :(得分:8)

我将模型作为字符串引用,并使用Bookshelf的registry plugin

var bookshelf = new Bookshelf( knex );
bookshelf.plugin( 'registry' );

然后我定义并创建一个模型:

var userModel = /*do bookshelf things*/;
bookshelf.model( 'User', userModel );

然后当我创建.hasMany时,我使用字符串来引用。

users: function() {
  return this.hasMany( 'User', 'roleId' );
},

答案 1 :(得分:1)

post.js

Bookshelf.plugin('registry')
var Category = require('./category')
var Post = Bookshelf.Model.extend({
    tableName: 'posts',
    hasTimestamps: true,
    categories: function () {
        return this.belongsTo('Category', 'category_id');
    },
});
module.exports = Bookshelf.model('Post',Post);

category.js

Bookshelf.plugin('registry');
var Post = require('./post');
var Category = Bookshelf.Model.extend({
    tableName: 'categories',
    hasTimestamps: true,
    posts : function () {
         return this.hasMany('Post');
    }
});
module.exports = Bookshelf.model('Category', Category);