RavenDB SelectMany不受支持

时间:2013-04-03 11:36:42

标签: linq ravendb

我试图根据子集合的值在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获取结果?

1 个答案:

答案 0 :(得分:1)

为此创建一个索引,输出要查询的值。 请注意,您不能像在此处一样执行任意代码:JaroWinklerCalculator.jaroWinkler(mf.Value, tf.Value) > .90d

但是你可以使用模糊查询,他们也会这样做。