RavenDb检查索引是否存在

时间:2012-12-12 22:09:23

标签: c# indexing ravendb

如何检查索引是否存在? - 在致电之前:

IndexCreation.CreateIndexes(typeof(MyIndexClass).Assembly, documentStore);

我看到的所有示例(包括示例项目中的示例)都在每次启动客户端时重新创建索引,这似乎不正确。

一般策略是什么?似乎有正常的CRUD操作,然后有管理命令,如上面的索引。人们只是创建一个控制台应用程序来执行管理员并与主应用程序分开部署/运行吗?

2 个答案:

答案 0 :(得分:18)

您无需检查是否存在。服务器将自动比较您发送的索引定义并检查它是否已存在。如果存在一个具有相同名称和定义的内容,那么它将保持不变。如果存在一个名称相同但定义已更改,则删除旧名称并创建新名称。

通常,在应用程序启动时,会在同一个应用程序中创建索引。对于可能位于global.asax中的Web应用程序,以及控制台/桌面应用程序,它只是启动代码的第一部分。

但有时这是不可能的,例如,如果您拥有许多不同的数据库,那么多租户应用程序通常会这样做。在这些情况下,您将在创建每个租户数据库时创建索引,并且在推出版本升级时可能需要更新或创建更多索引。

另外,我应该提一下,您可以通过几种不同的方式创建索引。

// scans the assembly for all indexes and creates them
IndexCreation.CreateIndexes(assembly, documentStore);

// scans a MEF catalog for all indexes and creates them
IndexCreation.CreateIndexes(catalog, documentStore);

// puts a single index the HARD way
documentStore.DatabaseCommands.PutIndex(...);

// puts a single index the easy way
documentStore.ExecuteIndex(new YourIndexCreationTask());

还有其他几个,但你明白了。

只是要彻底,如果你真的 希望检查索引存在,你可以使用:

documentStore.DatabaseCommands.GetIndex("YourIndex") != null

但这只会按名称检查,而不是按定义检查。你不需要它。

答案 1 :(得分:0)

主要问题和隐含问题的当代答案(RavenDB v4.x)将是:

如何检查索引是否存在?

无法检查特定索引,但是您可以像下面那样获得所有索引的列表(请参见official docs

IndexDefinition[] indexes = store.Maintenance.Send(new GetIndexesOperation(0, 100));

如何迁移数据库?

是的,您可以在每次启动该应用程序时运行索引创建。它适用于小型应用程序,如果不需要更改,则很快(请参阅official docs):

IndexCreation.CreateIndexes(typeof(YourClass).Assembly, _store);

但是,对于更大的应用程序,我建议您创建一个可在其中处理的迁移过程(可以是单独的工具,也可以是应用程序中的另一个端点):

  • 索引错误(例如,参见story of LINQ gotchas)。如果无法建立索引,则可能会发生索引错误,并且某些记录可能会从查询结果中掉出来。尽快获得有关索引错误的通知。请参阅文档中的“ How to Get Index Errors”。
  • 已执行迁移过程。许多数据库修改可能需要执行迁移脚本,该脚本随后需要数据库版本控制,确保您正在运行正确的版本等。为此请查看RavenMigrations NuGet软件包。