我有四个 Mongoose 模型,SoleTrader
、和。它们足够不同,我无法将它们全部合并到一个模式中,但又足够相似,以至于我经常需要一次查询或更改所有 4 种类型,并且很少关心它们是哪种类型。Partnership
Company
Trust
有没有办法做到这一点 - 可能通过将所有四种类型放在一个集合中 - 而无需每次进行四次数据库调用?
由于您使用的是mongoose-schema-extend
,因此您似乎可以创建一个简单的“基本”架构并扩展您的其他架构。如果要搜索所有这些,请使用基本模型。
例如:
// base schema
var PersonSchema = new Schema({
name : String
}, {
collection : 'users', // everything will get saved in the same collection
discriminatorKey : '_type'
});
// two schema's that extend off it
var EmployeeSchema = PersonSchema.extend({ department : String });
var EmployerSchema = PersonSchema.extend({});
// materialize all three into models
var Person = mongoose.model('Person', PersonSchema);
var Employee = mongoose.model('Employee', EmployeeSchema);
var Employer = mongoose.model('Employer', EmployerSchema);
...
// create some people
new Employee({
name : 'Homer Simpson',
department : 'Safety'
}).save(...);
new Employer({
name : 'Charles Montgomery Burns',
}).save(...);
...
// search across employers and employees
Person.find({ ... }, function(err, people) {
...
});
但是,我不得不说,根据鉴别键返回正确模型实例的广告行为对find()
我不起作用。