为什么不能在 CONTAINS 语句中调用 ISNULL?

2024-04-19

假设我有这样的 SQL 查询:

declare @input varchar(20)
select *
from myTable
where CONTAINS (myColumn, ISNULL(@input, 'replacement text'))

如果我尝试执行此操作,则会收到一条错误消息“‘ISNULL’附近的语法不正确”。我知道这是 ISNULL 的正确语法。是否有原因无法在 CONTAINS 语句内部调用 ISNULL?


尝试这个:

declare @input varchar(20)
SET @input=ISNULL(@input, 'replacement text')
select *
from myTable
where CONTAINS (myColumn, @input)

当您尝试将表达式放入存储过程调用时,也会出现同样的问题:

EXEC YourProcedure ISNULL(@input, 'replacement text') --will fail too

CONTAIN 需要一个字符串文字,请参阅包含 (Transact-SQL) http://technet.microsoft.com/en-us/library/ms187787.aspx

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么不能在 CONTAINS 语句中调用 ISNULL? 的相关文章

随机推荐