6

我有四个 Mongoose 模型,SoleTrader、和。它们足够不同,我无法将它们全部合并到一个模式中,但又足够相似,以至于我经常需要一次查询或更改所有 4 种类型,并且很少关心它们是哪种类型。PartnershipCompanyTrust

有没有办法做到这一点 - 可能通过将所有四种类型放在一个集合中 - 而无需每次进行四次数据库调用?

4

1 回答 1

6

由于您使用的是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()我不起作用。

于 2013-10-02T05:58:41.853 回答