1

嗨,我是 Mongo db 的新手,我有这样的类结构来存储表情符号和表情符号类别。我在表情符号类中创建了一个 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",

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

4

1 回答 1

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运算符

于 2014-06-18T15:05:04.207 回答