创建 SQL Server 条件全文索引



当服务器实例不支持全文搜索时,尽管有 IF 子句,以下查询将失败。有谁知道,为什么会发生这种情况以及如何实现这样的条件索引创建?

IF ((select SERVERPROPERTY('IsFullTextInstalled')) = 1)
    CREATE FULLTEXT INDEX 
      ON dbo.FulltextSearchIntermediates(
        [ContentUnderstand] LANGUAGE 1049
        ) 
      KEY INDEX [PK_dbo.FulltextSearchIntermediates] ON QuestionsFTS

错误消息是:

"未安装全文搜索,或者无法加载全文组件。"

这可能意味着它在编译时失败,因此如果未安装全文,则需要防止 sql 尝试编译。

declare @sql varchar(max)
set @sql = 'CREATE FULLTEXT INDEX 
      ON dbo.salesforcecontact(
        [LastName] LANGUAGE 1049
        ) 
      KEY INDEX [PK_dbo.FulltextSearchIntermediates] ON LastName'
IF ((select SERVERPROPERTY('IsFullTextInstalled')) = 1)
    exec sp_executesql '@sql'

最新更新