如何使用 MongoDB c# 驱动程序(版本 2)搜索嵌套条件?
How do I search nested criteria using MongoDB c# driver (version 2)?
我有一组文档,其中可以包含按类别分组的标准。结构可能如下所示:
{
"Name": "MyDoc",
"Criteria" : [
{
"Category" : "Areas",
"Values" : ["Front", "Left"]
},
{
"Category" : "Severity",
"Values" : ["High"]
}
]
}
我用来为条件创建嵌入式文档的 class 如下所示:
public class CriteriaEntity
{
public string Category { get; set; }
public IEnumerable<string> Values { get; set; }
}
用户可以从每个类别中选择条件进行搜索(作为 IEnumerable<CriteriaEntity>
进入函数)并且文档必须包含所有选定的条件才能返回。这是我的第一次尝试:
var filterBuilder = Builders<T>.Filter;
var filters = new List<FilterDefinition<T>>();
filters.Add(filterBuilder.Exists(entity =>
userCriterias.All(userCriteria =>
entity.Criteria.Any(entityCriteria =>
entityCriteria.Category == userCriteria.Category
&& userCriteria.Values.All(userValue =>
entityCriteria.Values.Any(entityValue =>
entityValue == userValue))))));
但是我收到错误:"Unable to determine the serialization information for entity..."。我怎样才能让它工作?
MongoDB.Driver 2.0 不支持 Linq.All。无论如何,您的任务可以通过以下方式解决:
var filterDefinitions = new List<FilterDefinition<DocumentEntity>>();
foreach (var criteria in searchCriterias)
{
filterDefinitions
.AddRange(criteria.Values
.Select(value => new ExpressionFilterDefinition<DocumentEntity>(doc => doc.Criterias
.Any(x => x.Category == criteria.Category && x.Values.Contains(value)))));
}
var filter = Builders<DocumentEntity>.Filter.And(filterDefinitions);
return await GetCollection<DocumentEntity>().Find(filter).ToListAsync();
我有一组文档,其中可以包含按类别分组的标准。结构可能如下所示:
{
"Name": "MyDoc",
"Criteria" : [
{
"Category" : "Areas",
"Values" : ["Front", "Left"]
},
{
"Category" : "Severity",
"Values" : ["High"]
}
]
}
我用来为条件创建嵌入式文档的 class 如下所示:
public class CriteriaEntity
{
public string Category { get; set; }
public IEnumerable<string> Values { get; set; }
}
用户可以从每个类别中选择条件进行搜索(作为 IEnumerable<CriteriaEntity>
进入函数)并且文档必须包含所有选定的条件才能返回。这是我的第一次尝试:
var filterBuilder = Builders<T>.Filter;
var filters = new List<FilterDefinition<T>>();
filters.Add(filterBuilder.Exists(entity =>
userCriterias.All(userCriteria =>
entity.Criteria.Any(entityCriteria =>
entityCriteria.Category == userCriteria.Category
&& userCriteria.Values.All(userValue =>
entityCriteria.Values.Any(entityValue =>
entityValue == userValue))))));
但是我收到错误:"Unable to determine the serialization information for entity..."。我怎样才能让它工作?
MongoDB.Driver 2.0 不支持 Linq.All。无论如何,您的任务可以通过以下方式解决:
var filterDefinitions = new List<FilterDefinition<DocumentEntity>>();
foreach (var criteria in searchCriterias)
{
filterDefinitions
.AddRange(criteria.Values
.Select(value => new ExpressionFilterDefinition<DocumentEntity>(doc => doc.Criterias
.Any(x => x.Category == criteria.Category && x.Values.Contains(value)))));
}
var filter = Builders<DocumentEntity>.Filter.And(filterDefinitions);
return await GetCollection<DocumentEntity>().Find(filter).ToListAsync();