我试图根据子集合的值在RavenDB中查找一个或多个文档。
我有以下课程
public class GoldenDocument
{
public GoldenDocument()
{
LinkedDocuments = new List<LinkedDocument>();
MergeMatchFields = new List<MergeMatchField>();
}
public string Id { get; set; }
public Guid SourceRowId { get; set; }
public List<MergeMatchField> MergeMatchFields { get; set; }
public List<LinkedDocument> LinkedDocuments { get; set; }
}
集合MergeMatchFields
public class MergeMatchField
{
public string Id { get; set; }
public Guid OriginId { get; set; }
public string Name { get; set; }
public MatchType MatchType { get; set; }
public double MatchPerc { get; set; }
public string Value { get; set; }
}
在List<MergeFields> mergeFields
集合中,我的值尚未存储在RavenDB中。通过执行以下查询,将值与RavenDB文档中的值进行比较,以查找是否可能匹配:
using (var session = documentStore.OpenSession())
{
var docs = from gd in session.Query<GoldenDocument>()
from mf in gd.MergeMatchFields
from tf in mergeFields
where mf.Name == tf.Name
&& JaroWinklerCalculator.jaroWinkler(mf.Value, tf.Value) > .90d
&& !string.IsNullOrEmpty(mf.Value)
select gd;
}
我理解ravenDB不支持SelectMany()
所以我如何从Document store获取结果?
答案 0 :(得分:1)
为此创建一个索引,输出要查询的值。
请注意,您不能像在此处一样执行任意代码:JaroWinklerCalculator.jaroWinkler(mf.Value, tf.Value) > .90d
但是你可以使用模糊查询,他们也会这样做。