RavenDB:索引来自多个集合的文档

时间:2011-08-22 13:19:21

标签: ravendb

我有几个文档集合偶尔需要合并为一个索引以用于报告目的。

此常见问题解答提供了在Raven Studio中编写此类索引的解决方案:http://ravendb.net/faq/indexing-across-entities

虽然我知道我不会得到完整的编译时检查,但我试图避免完全未经检查的代码:

public class Assets_ById : AbstractIndexCreationTask
{
    public override IndexDefinition CreateIndexDefinition()
    {
        return new IndexDefinition
        {
            Map = @"from doc in docs
                    where doc[""@metadata""][""Raven-Entity-Name""] == ""Cars"" ||
                          doc[""@metadata""][""Raven-Entity-Name""] == ""Trains"" ||
                          doc[""@metadata""][""Raven-Entity-Name""] == ""Boats"" ||
                          doc[""@metadata""][""Raven-Entity-Name""] == ""Planes""
                    select new
                    {
                        Cost = doc.Cost,
                        Id = doc.Id,
                        Name = doc.Name,
                        Type = doc.Type,
                    };"
        }
    }
}

是否有类似于通用AbstractIndexCreationTask<T>的东西允许我用lambda表达式定义异构索引?

2 个答案:

答案 0 :(得分:5)

您可以使用WhereEntityIs(名称),如下所示:

from doc in docs.WhereEntityIs<Vehicle>("Cars", "Trains", "Boats", "Planes")
select new 
{
  doc.Cost,
  doc.Name,
  doc.Type
}

答案 1 :(得分:4)

看看这里:https://groups.google.com/forum/#!topic/ravendb/9wvRY0OiGBs

基本上是同一个问题,简短的回答是:

  

“现在没有更好的选择,但将来会有”