c# - 使用 C# 驱动程序使用 Elemmatch 查询 MongoDB
问题描述
我在将查询(相对简单)从 Mongo Shell 转换为 C#(可以是 linq 或过滤器生成器)时遇到问题。我想通过一些字段(在我的示例中EntityId
)ActivityDate
和数组中存在的字段(在我的示例中UnCommonFields
)进行查询。
数据示例:
{
"_id" : ObjectId("5ded105e90424e1c0e6fda05"),
"EntryId" : NumberLong(1111111),
"EntityId" : "10000007",
"EntityType" : NumberInt(5),
"ActivityItemId" : "1,4,16172532",
"ActivityDate" : ISODate("2015-04-13T03:50:55.000-0400"),
"CreateDate" : ISODate("2017-12-13T19:07:07.757-0500"),
"UpdateDate" : ISODate("2017-12-13T19:07:07.757-0500"),
"ActivityItemStatus" : NumberInt(2),
"ActivityTypeId" : NumberInt(2),
"Currency" : "USD",
"Amount" : "-10.7800",
"ActivityItemDescription" : "Stackoverflow example",
"DisplayLevel" : NumberInt(10),
"UnCommonFields" : [
{
"k" : "CardPresent",
"v" : NumberLong(2)
},
{
"k" : "PreAuthDate",
"v" : ISODate("2015-04-11T08:47:05.000-0400")
},
{
"k" : "TransactionDate",
"v" : ISODate("2015-04-13T03:50:55.000-0400")
},
{
"k" : "ActivityItemStatus",
"v" : NumberLong(2)
},
{
"k" : "MerchantName",
"v" : "StackOverflow POS"
},
{
"k" : "TerminalCity",
"v" : "TLV"
},
{
"k" : "TerminalState",
"v" : "IL"
},
{
"k" : "TerminalCountry",
"v" : "IL"
},
{
"k" : "Fee",
"v" : 0.0
},
{
"k" : "IsDecline",
"v" : false
},
{
"k" : "BillingAmount",
"v" : -10.78
},
{
"k" : "BillingCurrency",
"v" : "USD"
},
{
"k" : "ForeignAmount",
"v" : -10.78
},
{
"k" : "ForeignCurrency",
"v" : "USD"
},
{
"k" : "FxRate",
"v" : 1.0
},
{
"k" : "MaskedCardNumber",
"v" : "530000XXXXXX6699"
}
]
}
我想在 Mongo shell 上编写的查询如下所示:
db.getCollection("ActivityWriterTest").find(
{$and:
[
{EntityId:"10000007"},
{ ActivityDate: { $gte: ISODate("2015-04-12T03:50:55.000"), $lte: ISODate("2015-04-14T03:50:55.000") } },
{UnCommonFields : { $elemMatch : {"k" : "ForeignAmount", "v" : {$in: [-10.78, -15.85] } }}}
]
})
这是我在 C# 代码上写的部分:它包括两个第一个过滤器,它按预期工作
_activityContext.ActivityData.Find(x => x.EntityId == accountHolderId && x.ActivityDate >= requestDetails.FromDate && x.ActivityDate <= requestDetails.ToDate)
我尝试以多种方式实现 elemactch,但没有成功。知道如何翻译和整合 elemmatch 作为查询的一部分吗?
我使用 MongoDB 驱动程序 2.10
解决方案
您尚未展示您的 C# 类的外观,但我假设您正在使用System.Object
for,UnCommonFields.v
因为您在那里有不同类型的值。
要构建$elemMatch查询,您需要使用Builders<T>.Filter
MongDB C# 驱动程序中的类型。假设Model
代表您的实体并Uncommonfield
代表嵌套对象,您可以运行以下查询:
var query = Builders<Model>.Filter.And(
Builders<Model>.Filter.Eq(x => x.EntityId, accountHolderId),
Builders<Model>.Filter.Gte(x => x.ActivityDate, requestDetails.FromDate),
Builders<Model>.Filter.Lte(x => x.ActivityDate, requestDetails.ToDate),
Builders<Model>.Filter.ElemMatch(x => x.UnCommonFields,
Builders<Uncommonfield>.Filter.And(
Builders<Uncommonfield>.Filter.Eq(x => x.k, "ForeignAmount"),
Builders<Uncommonfield>.Filter.In(f => f.v, new object[]{ -10.78, -15.85 })
)
)
);
var doc = _mongoDBCollection.Find(query).First();
LINQ版本:
var q = from doc in _mongoDBCollection.AsQueryable()
where doc.EntityId == accountHolderId
where doc.ActivityDate >= requestDetails.FromDate
where doc.ActivityDate <= requestDetails.ToDate
where doc.UnCommonFields.Any(x => x.k == "ForeignAmount" && new object[] { -10.78, -15.85 }.Contains(x.v))
select doc;
推荐阅读
- java - 有没有办法在 Kotlin 活动和 Java 活动之间获取结果?
- python-3.x - pythondns - 两个相同的字符串返回不相等
- javascript - 如何从我的 gmail 帐户中获取我的签名?节点JS
- python - 如何使用 pyspark 包含外部 python 模块
- python - 在 Telegram Bot 上获取照片的 file_id 时出错
- excel - 根据条件用一个单元格中的值填充两列
- sql - 无法创建大小为 8330 的稀疏数据大于允许的最大稀疏数据大小 8023 的行
- installation - 如何通过 Pip install rasa 成功安装 rasa?
- javascript - 用于将图像从 Imgur 拉到不和谐机器人中的 API
- sql - SQL 空间查询 - 确定纬度/经度点落入哪个多边形