BenutzermodellAbfrage Verwandte BelongsToMany
var User = db.Model.extend({
initialize: function() {
this.on('creating', this.generateId, this);
},
tableName: 'users',
hasTimestamps: true,
hidden: ['password'],
companies: function(){
return this.belongsToMany(
require('./company'),
'users_companies',
'user_id',
'company_id'
)
},
charities: function(){
return this.belongsToMany(
require('./charity'),
'users_charities',
'user_id',
'charity_id'
).withPivot(['company_id']);
},
generateId: function(model, attrs, options) {
model.set('id', uuid.v4());
}
});
-Controller
exports.getAllCharities = function(req, res){
new User({ id: req.user.id })
.charities()
.fetch()
.then(function(charities){
return res.json(charities.toJSON());
})
Die oben genannten Arbeiten, aber ich brauche der Lage sein, die zurück gemeinnützige Organisationen zur Abfrage durch den Drehfeld ‚company_id‘ zu filtern. Wenn Sie charities.where ({company_id: 1}). Fetch() versuchen, erhalten Sie eine Ausnahme, die angibt, wo keine Funktion von Wohltätigkeitsorganisationen besteht.
eine Lösung
new User({ id: req.user.id })
.charities()
.query('where', 'company_id', '=', req.query.companyid)
.fetch()
.then(function(charities){
return res.json(charities.toJSON())
})
gefunden
kann den Unterschied zwischen, dass jemand erklären und .where({company_id: req.query.companyid})