我有几个文档集合偶尔需要合并为一个索引以用于报告目的。
此常见问题解答提供了在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表达式定义异构索引?
答案 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
基本上是同一个问题,简短的回答是:
“现在没有更好的选择,但将来会有”