如何参数化以下查询?(顺便说一句,我使用的是全文索引表,因此CONTAINS()
)
SELECT * FROM Table WHERE CONTAINS(Column, 'cat OR dog')
and ((column NOT LIKE '%[^ cat OR dog]%'));
这没有用:
DECLARE @term1 VARCHAR(10);
DECLARE @term2 VARCHAR(10);
SET @term1 = 'cat';
SET @term2 = 'dog';
SET @term3 = @term1 + ' ' + 'OR' + ' ' + @term2;
SET @term4 = '[^ @term1 OR @term2 ]' ;
SELECT * FROM table WHERE CONTAINS(column, @term3) <--up to this point works
AND (column NOT LIKE '%[@term4]%'); <--this part doesn't include the second term (@term2)
如果您想最终解决这个问题,我的全文索引表如下所示:
animalListID AnimalsList
1 cat dog
2 cat
3 cat dog bird
(基本上我需要SELECT
返回带有'cat dog'和'cat'而不是'cat dog bird'的行的语句的参数化版本)
**这是我数据的一个非常简化的版本,但问题与我试图实现的概念完全匹配。该表将有数百万行,每行中有许多术语。