如何在Mongodb中使用MongodbRef引用文档以及如何获取组合文档

时间:2014-06-17 13:29:41

标签: mongodb mongodb-.net-driver mongodb-query mongo-collection mongo-c-driver

您好我是Mongo db的新手我有类似的类结构用于存储表情符号和表情符号类别。我在smilies类中创建了一个mongodef属性,用于引用表情符号类别集合,但是能够获得表情符号类别名称...

public class smilies {
    public ObjectId _id { get; set; }
    public MongoDBRef scat_name{ get; set; }
    public string smil_url { get; set; }
    public string smil_detail { get; set; }
}

public  class smilies_category {
    public ObjectId _id { get; set; }
    public string scat_name { get; set; }
}

我正在使用下面的代码来获取记录和记录,但只来自一个文档

function void getSmilies(){
  var refDocument = new BsonDocument { 
            {"$ref", "smil_scat_id"}, 
            {"$id", "539ef7c2e46b621314956e3b"}
        };

        var query = Query.EQ("smilies_category", refDocument);
        var result = db.GetCollection("smilies").Find(query)

}

现在我想要的是像

这样的结果集
 "_id" : ObjectId("539f3ec1e46b62120023d364"),
 "scat_name : "Bussines",
 "smil_url" : "www.gmail.com",
 "smil_detail" : "Ok fine",

我们怎样才能做到这一点?      我走得对吗?      请让我知道解决方案

1 个答案:

答案 0 :(得分:0)

你的班级类型应该是

public class smilies {
    public ObjectId _id { get; set; }
    public MongoDBRef scat_name{ get; set; }
    public string smil_url { get; set; }
    public string smil_detail { get; set; }
    public string[] CategoryName {get; set:}
}

MongoDB文件将

{
_id:"".
smil_url :"",
...
...

CategoryName:[
            "cat1",
            "Cat2",
            ....
          ]
}

并将您的查询更改为C#驱动程序中 $ in 运算符