当服务器实例不支持全文搜索时,尽管有 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'