5

我有一个猫鼬模型模式,我正在尝试为一些预先存在的 mongodb 文档构建它。现有的 mongo 文档具有对同一集合的自引用。我试图创建一个表示这种关系的模式,然后尝试使用populate 方法。架构如下所示(为简洁起见,删除了一些属性):

var fileSchema = new Schema({
    _id: { type: String },
    pcap: {
        files: [{ type: Schema.Types.ObjectId, ref: 'Files' }]
    }
});

var file = artifactConn.model('Files', fileSchema, 'info');

然后我使用上面的模型进行查询,然后像这样填充:

models.file.findById("91320684-9a1a-4f2a-a03f-63a7a208ec9b")
.populate('pcap.files') // have also tried just 'files' w/ the same result
.exec(function (err, file) {
    if (!err) {
        console.log(file);
    } else {
        console.log(err);
    }
});

这导致了这个

{ _id: '91320684-9a1a-4f2a-a03f-63a7a208ec9b',
  pcap: 
   { files: [] }
}

如果我在 mongohub 中检查我的文档,它看起来像这样

{ "_id" : "91320684-9a1a-4f2a-a03f-63a7a208ec9b",
  "pcap" : {
    "files" : [ 
      { "_id" : "e4eed129-b4aa-46fc-8df2-3f3f92e6fe53" }, 
      { "_id" : "8c0ecb98-452e-475d-a521-feba5c3d1426" }, 
      { "_id" : "4b87c467-f396-4bcf-a7b0-8419e8441ec0" } ] } }

我对填充的调用做错了吗?这是我设置架构的方式吗?它是存储数据的方式吗?

4

2 回答 2

4

您的架构不正确。您拥有的架构将匹配这样的集合:

{ "_id" : "91320684-9a1a-4f2a-a03f-63a7a208ec9b",
  "pcap" : {
    "files" : [ 
      { ObjectId("e4eed129-b4aa-46fc-8df2-3f3f92e6fe53") }, 
      { ObjectId("8c0ecb98-452e-475d-a521-feba5c3d1426") }, 
      { ObjectId("4b87c467-f396-4bcf-a7b0-8419e8441ec0") } ] } }

架构应该是:

var fileSchema = new Schema({
    _id: { type: String },
    pcap: {
        files: [{ 
            _id: { type: String, ref: 'Files' }
        }]
    } });

那应该行得通。

于 2013-04-16T14:04:47.317 回答
3

架构看起来不错。以相同的方式存储数据,你应该很好:例如

{ "_id" : "91320684-9a1a-4f2a-a03f63a7a208ec9b",
  "pcap" : {
  "files" : [ ObjectId("e4eed129-b4aa-46fc-8df2-3f3f92e6fe53"), ObjectId("8c0ecb98-452e-475d-a521-feba5c3d1426"), ObjectId("4b87c467-f396-4bcf-a7b0-8419e8441ec0")] 
  } 
}

然后

Model.find(..).populate('pcap.files').exec(..)
于 2013-04-17T01:30:53.793 回答