Joe*_*ris 11 .net c# mongodb mongodb-.net-driver
我在mongodb中有一个文档,结构类似于:
{
"_id": "abcdef01234",
"Name": "Product A",
"Dimensions": [
{
"Height": 32,
"Width": 64
},
{
"Height": 16,
"Width": 32
},
{
"Height": 8,
"Width": 16
}
]
}
Run Code Online (Sandbox Code Playgroud)
我还有一个定义为表示维度的类(上面的子文档)
public class Dimension
{
public int Height { get; set; }
public int Width { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我以这种方式选择"产品A"文档:
MongoServer srv = MongoServer.Create(myConnStr);
BsonDocument doc = srv["db"]["products"].FindOneById(ObjectId.Parse("abcdef01234"));
BsonValue dimensionsVal = doc["Dimensions"];
Run Code Online (Sandbox Code Playgroud)
现在我有一个名为dimensionsVal的BsonValue,它的类型为BsonArray.我真正想要的是List <Dimension>.如何将dimensionsVal转换为List <Dimension>?
编辑 维度类实际上比我描述的要复杂得多.由于内存问题,我希望将Dimensions与产品分开.我想将产品保留在内存中,但不是(可能是巨大的)维度列表.因此,我不希望将List作为Product类的属性.
Joe*_*ris 24
以下是它的完成方式:
using MongoDB.Bson.Serialization;
MongoServer srv = MongoServer.Create(myConnStr);
BsonDocument doc = srv["db"]["products"].FindOneById(ObjectId.Parse("abcdef01234"));
BsonValue dimVal = doc["Dimensions"];
List<Dimension> d = BsonSerializer.Deserialize<List<Dimension>>(dimVal.ToJson());
Run Code Online (Sandbox Code Playgroud)
更新:
您可能正在寻找包含/排除功能。在 C# 驱动程序中,它这样做了:
// load products without array of Dimensions
MongoCursorInstance.SetFields(Fields.Exclude("Dimensions"));
//load empty product with Dimensions and _id
MongoCursorInstance.SetFields(Fields.Include("Dimensions"));
Run Code Online (Sandbox Code Playgroud)
为什么不直接为产品创建类呢?在这种情况下,驱动程序将能够自动反序列化数据:
class Product
{
[BsonId]
public ObjectId Id { get; set; }
public string Name{ get; set; }
public List<Dimension> Dimensions{ get; set; }
}
var product = srv["db"]["products"].FindOneByIdAs<Product>();
var dimentions = product.Dimensions;
Run Code Online (Sandbox Code Playgroud)
但如果你不想创建Product
类,你可以这样做:
BsonArray dimensionsVal = doc["Dimensions"].AsBsonArray;
var list = new List<Dimension>();
foreach (BsonValue value in dimensionsVal)
{
var bsonDoc = (BsonDocument) value;
var d = new Dimension();
d.Height = bsonDoc["Height"];
d.Width = bsonDoc["Width"];
list.Add(d);
}
Run Code Online (Sandbox Code Playgroud)