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 的方式。
提前感谢您的帮助!