【问题标题】:How to get value from object in document using MondoDB driver C#?如何使用 MongoDB 驱动程序 C# 从文档中的对象获取值?
【发布时间】:2020-08-14 11:47:01
【问题描述】:

我将数据存储在 MongoDB 中,如下所示:

_id:5e72196fa7e42815ece552c0
dates: Object
   StartDate:2020-06-01T00:00:00.000+00:00
status:"Active"

我的自定义类如下:

public class MyCustomClass
{
    public string Status { get; set; }

    public DateTime StartDate { get; set; }
}

所以使用下面的代码我得到的是状态而不是日期。

var projection = Builders<Entity>.Projection
                                .Exclude(x => x.Id)
                                .Include(x => x.Status)
                                .Include(x => x.Dates.StartDate);
 var data = await _collection.Find(FilterDefination).Project<MyCustomClass>(projection).FirstAsync();

我错过了什么?

【问题讨论】:

    标签: c# mongodb mongodb-query projection


    【解决方案1】:

    首先,这种投影是聚合投影。我不得不把它移到Aggregate

    dummies.Aggregate().Match(FilterDefinition<Entity>.Empty).Project(...)
    

    即使它不起作用,因为 C# 驱动程序没有很好地处理投影:

    var projection = new ProjectionDefinitionBuilder<Entity>().Include("$dates.StartDate");
    // throws MongoDB.Driver.MongoCommandException: 'Command aggregate failed: Invalid $project :: caused by :: FieldPath field names may not start with '$'..'
    var data = dummies.Aggregate().Match(FilterDefinition<Entity>.Empty).Project(projection).FirstAsync().GetAwaiter().GetResult();
    

    最终结果是使用BsonDocumentProjectionDefinition:

    string connectionString = "mongodb://localhost:27017";
    var client = new MongoClient(connectionString);
    var db = client.GetDatabase("inner");
    var dummies = db.GetCollection<Entity>("Dummy");
    //dummies.InsertOne(BsonDocument.Parse("{dates: {StartDate: new Date(\"2020-06-01\")}, status: \"Active\"}"));
    
    var projection = new BsonDocumentProjectionDefinition<Entity, MyCustomClass>(BsonDocument.Parse("{\"StartDate\": \"$dates.StartDate\", _id: 0, status: 1}"));
    var data = dummies.Aggregate().Match(FilterDefinition).Project(projection).FirstAsync().GetAwaiter().GetResult();
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-05-08
      • 2014-08-18
      • 1970-01-01
      • 2012-10-31
      • 1970-01-01
      • 2021-11-02
      相关资源
      最近更新 更多