- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 AsQueryable 和 LINQ 函数查询 mongodb 数据库。
我当前的数据库结构是我有一些集合,主要是在 C# 中定义的记录,如下所示:
public class Record
{
[BsonElement("formName")]
public string FormName { get; set; }
[BsonElement("created")]
public DateTime Created { get; set; }
[BsonElement("createdBy")]
public string CreatedBy { get; set; }
[BsonId]
[BsonIgnoreIfDefault]
[BsonRepresentation(BsonType.ObjectId)]
private string InternalId { get; set; }
[BsonElement("recordId")]
[Newtonsoft.Json.JsonProperty("recordId")]
public string Id { get; set; }
[BsonElement("organisationId")]
public string OrganisationId { get; set; }
// TODO: Consider making configurable
private string appName = "MediLog";
[BsonElement("appName")]
public string AppName
{
get { return this.appName; }
set { this.appName = value; }
}
[BsonElement("schemaVersion")]
public int SchemaVersion { get; set; }
[BsonElement("contents")]
public ExpandoObject Contents { get; set; }
[BsonElement("modified")]
public DateTime Modified { get; set; }
[BsonElement("modifiedBy")]
public string ModifiedBy { get; set; }
[BsonElement("majorVersion")]
public int MajorVersion { get; private set; }
[BsonElement("minorVersion")]
public int MinorVersion { get; private set; }
[BsonElement("version")]
public string Version
{
get
{
return (MajorVersion + "." + MinorVersion);
}
set
{
MajorVersion = Convert.ToInt32(value?.Substring(0, value.IndexOf(".", StringComparison.OrdinalIgnoreCase)), CultureInfo.InvariantCulture);
MinorVersion = Convert.ToInt32(value?.Substring(value.IndexOf(".", StringComparison.OrdinalIgnoreCase) + 1), CultureInfo.InvariantCulture);
}
}
}
Contents
这是一个
ExpandoObject
这就是我的问题所在。
var collection =
database.GetCollection<Record>("recordData").AsQueryable()
.Where(x => x.Contents.SingleOrDefault(z => z.Key == "dateOfBirth").Value.ToString().Length > 0)
.ToList();
var collection1 = database.GetCollection<Record>("recordData").AsQueryable()
.Where(x => (DateTime)(x.Contents.SingleOrDefault(z => z.Key == "dateOfBirth").Value) > DateTime.Now)
.ToList();
System.InvalidOperationException
HResult=0x80131509
Message=Convert({document}{contents}.SingleOrDefault(z => (z.Key == "dateOfBirth")).Value) is not supported.
var collection =
database.GetCollection(“recordData”).AsQueryable()
.Where(x => (DateTime)x.Contents.First(z => z.Key == “dateOfBirth”).Value > DateTime.Now ).ToList();
System.NotSupportedException: ‘The expression tree is not supported: {document}{contents}’
最佳答案
无论你想传递给 .Where()
方法是一个需要翻译成MongoDB查询语言的表达式树。 C# 编译器将接受 ExpandoObject
的方法如 SingleOrDefault
(扩展方法)但是当这种表达式树需要转换为 Mongo 查询时,这将在运行时失败。ExpandoObject
没什么特别的当您使用 MongoDB 时。它必须以某种方式翻译成 BSON 文档(MongoDB 格式),例如下面的代码:
dynamic o = new ExpandoObject();
o.dateOfBith = new DateTime(2000, 1, 1);
r.Contents = o;
col.InsertOne(r);
ExpandoObject
与
BsonDocument
相同或
Dictionary<string, T>
所以它只是变成:
{ "_id" : ObjectId(",,,"), "contents" : { "dateOfBith" : ISODate("2000-01-01T07:00:00Z") } }
StringFieldDefinition
您可以使用的类,因为您无法从
ExpandoObject
构建表达式树以强类型方式:
var fieldDef = new StringFieldDefinition<Record, DateTime>("contents.dateOfBith");
var filter = Builders<Record>.Filter.Gt(fieldDef, new DateTime(2000, 1, 1));
var res = col.Find(filter).ToList();
关于c# - 在 Mongodb C# 中使用 AsQueryable 进行过滤 - ExpandoObject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61851443/
我想知道是否可以迭代包含 Expando 对象数组的 ExpandoObject? 我目前正在解析一些具有如下文件结构的 JSON: "event": [{ "name": "BEG
我有一个包含 ExpandoObjects 字典的列表。我将它绑定(bind)到网格,但现在我想对列表进行排序。 var rows = new List(); for
我有一个继承的 .NET 4.0 应用程序,它作为 Windows 服务运行。无论如何,我都不是 .NET 专家,但是在编写了 30 多年的代码之后,我知道如何找到自己的出路。 当服务第一次启动时,它
我正在尝试将方法(函数)分配给具有此签名的 ExpandoObject: public List CreateList(string input1, out bool processingStatus
ExpandoObject 是否有方便的工厂方法?有点像,我不知道, dynamic disney = new ExpandoObject("First", "Donald", "Last", "Du
我是 C# 的新手,在 Stackoverflow.com 上遇到了很多问题,但没有找到满足我要求的解决方案。所以最后在这里发帖。 我的要求是从数据表列名创建动态属性,并将值设置为数据表中的动态属性。
这是基于 MVVM 的 WPF 项目: 我在对话框的 View 模型中使用 ExpandoObject,它工作得很好,因为它实现了 INotifyPropertyChanged,我可以直接在 XAML
我正在使用 Json.Net 将 json 结果反序列化为 ExpandoObjects使用如下代码: var converter = new ExpandoObjectConverter()
我正在获取一个 JSON 对象(可能包含多个级别的 JSON 数组等),我想将其转换为 ExpandoObject。 我想出了如何在运行时向 ExpandoObject 添加简单属性,因为它实现了 I
dynamic model = new ExpandoObject(); model.Data = "asdf"; List listOfx = new List(); for (int i = 0;
我真的很喜欢匿名类型语法。例如 new {a = 1, b = 2, c = 25.2} 如果 Expando 或 Dictionary 有这样的版本就好了。有办法吗? 最佳答案 你可以这样做 Di
在我的应用程序中,我必须使用 ExpandoObject 才能在运行时创建/删除属性;但是,我必须将函数返回的 ExpandoObject 映射到相应的对象/类。所以我想出了一个可以完成这项工作但有
有没有办法向 ExpandoObject 添加一个与字符串值同名的属性? 例如,如果我有: string propName = "ProductNumber"; dynamic obj = new S
今天研究 C# 动态时,有些事情让我感到惊讶(我从来没有经常使用它们,但最近我一直在试验 Nancy 网络框架)。我发现我不能这样做: dynamic expando = new ExpandoObj
ExpandoObject添加到 .NET 4 的类允许您在运行时任意设置对象的属性。 与使用 Dictionary 相比,这有什么优势吗? ,甚至是 Hashtable ?据我所知,这不过是一个哈希
我需要创建一个对象,该对象具有动态命名的属性,例如: john max asdf 这可能吗? 最佳答案 是的,绝对是。只需将其用作 IDictionary填充: IDictionary
如果我有这样的 ExpandoObject: dynamic d = new ExpandoObject(); d.x = "a"; d.y = "b"; 并使用 JsonFormatter 将其通过
我写了一个漂亮的函数,它可以接受 system.object ,反射(reflect)其属性并将对象序列化为 JSON 字符串。它看起来像这样: public class JSONSerializer
我正在尝试编写一个通用实用程序,以便从 .NET 外部通过 COM 使用(/skip long story)。无论如何,我正在尝试向 ExpandoObject 添加属性,并且需要将 Property
编辑: ExpandoObject与 MEF 配合良好。我只是有一个语法错误。傻我。 我目前正在使用 ExpandoObjects动态创建 DelegateCommand给我的ViewModels .
我是一名优秀的程序员,十分优秀!