在C#中的管道中将$and用于mongodbgregate()函数驱动程序
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在C#中的管道中将$and用于mongodbgregate()函数驱动程序,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1243字,纯文字阅读大概需要2分钟。
内容图文
![在C#中的管道中将$and用于mongodbgregate()函数驱动程序](/upload/InfoBanner/zyjiaocheng/885/841bcadbfb11429fbb60a5e6c542e2ae.jpg)
我正在尝试使用C#中的mongodb聚合框架.
我希望能够在查询中放入$and.
这是我要运行的mongodb查询-
db.students.aggregate(
{
$match:
{
name:"mira",
$and:[{date:{$gte:ISODate("2015-03-01T00:00:00")}},
{date:{$lte:ISODate("2015-04-01T00:00:00")}}]
},
{
$group:{"_id":"$subject", "$sum":"$marks"}
}
)
我创建了与mongodb查询相对应的匹配项,但此处不正确,因为在括号中出现了编译器错误.
我的C#代码如下-
var match = new BsonDocument {
{
"$match",
new BsonDocument
{
{
"name", "mira"
}
},
{
"$and", new BsonDocument{ {
new BsonDocument
{
{ "date",
new BsonDocument { { "$gte", beginDate.ToString("yyyy-MM-ddThh:mm:ss") } }
}
},
new BsonDocument
{
{ "date",
new BsonDocument { { "$lte", endDate.ToString("yyyy-MM-ddThh:mm:ss") } }
}
}
}}
}
} } ;
有人可以指导我如何将$and匹配放入我的C#代码中吗?
解决方法:
您可以这样做:
var match= new BsonDocument("$match", Query.And(Query.EQ("name", "mira"),
Query.GTE("date", beginDate.ToString("yyyy-MM-ddThh:mm:ss")),
Query.LTE("date", endDate.ToString("yyyy-MM-ddThh:mm:ss"))).ToBsonDocument());
或者,您也可以遵循@chridam推荐的变体:
var match = new BsonDocument
{
{
"$match",
new BsonDocument
{
{ "name", "mira" },
{ "date", new BsonDocument
{
{"$gte", beginDate.ToString("yyyy-MM-ddThh:mm:ss")},
{"$lte", endDate.ToString("yyyy-MM-ddThh:mm:ss") }
}
}
}
}
};
内容总结
以上是互联网集市为您收集整理的在C#中的管道中将$and用于mongodbgregate()函数驱动程序全部内容,希望文章能够帮你解决在C#中的管道中将$and用于mongodbgregate()函数驱动程序所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。