13

TLDR;如何使用实体框架 5 编码迁移添加全文索引

我在使用实体框架迁移向数据库添加全文索引时遇到问题。它需要从一开始就在那里,所以我正在尝试修改自动生成的 InitialCreate 迁移以添加它。

因为没有办法通过 DbMigrations API 来实现,所以我求助于在“Up”代码的末尾运行内联 sql。

Sql("create fulltext catalog AppNameCatalog;");
Sql("create fulltext index on Document (Data type column Extension) key index [PK_dbo.Document] on AppNameCatalog;");

当它运行时,一切都被创建得很好,直到它到达这个 sql,然后它抛出 sql 错误' CREATE FULLTEXT CATALOG 语句不能在用户事务中使用。'。这是预期的并按设计工作。

值得庆幸的是 Sql() 有一个重载,允许您在迁移事务之外运行 sql。惊人的!我想。

Sql("create fulltext catalog AppNameCatalog;", true);
Sql("create fulltext index on Document (Data type column Extension) key index [PK_dbo.Document] on AppNameCatalog;", true);

但是修改代码以执行此操作(见上文)会导致新的超时错误“超时已过期”。在操作完成之前超时时间已过或服务器没有响应。'

我试过吐出sql并手动运行它,它工作正常。我还区分了在事务之外运行和不运行生成的 sql,它们是相同的,所以它必须是执行 sql 的方式。

提前感谢您的帮助!

4

1 回答 1

7

我有一个类似的问题。我的 InitialCreate 迁移正在创建一个表,然后尝试向该表添加一个全文索引,使用重载的 Sql() 来指示它需要在事务之外执行。我也遇到了超时错误,我怀疑这是由于线程死锁。

通过使用 Sql() 调用而不是 CreateTable() 并将 CREATE FULL TEXT CATALOG 和 CREATE FULL TEXT INDEX 语句合并到单个 Sql() 调用中,我可以让它在某些情况下工作。然而,这并不是很可靠。有时它会起作用,有时它会因相同的超时错误而失败。

我找到的唯一可靠的解决方案是将目录和全文索引的创建移到单独的迁移中。

于 2013-05-22T11:35:51.520 回答