小心 ------ SQL SERVER (1)
查询1:
查询2:
查询3:
WHY?????????????????????????????
SELECT * FROM #OPTable WHERE heroName IN ('Monkey D. Luffy','Roronoa Zoro','Nami')
在这个查询中IN 后面的括号中有三个字符串的值,分别是'Monkey D. Luffy','Roronoa Zoro'和'Nami'
然而
DECLARE @sHeroName NVARCHAR(60)
SET @sHeroName = '''Monkey D. Luffy'',''Roronoa Zoro'',''Nami'''
SELECT @sHeroName AS HeroName -- 'Monkey D. Luffy','Roronoa Zoro','Nami'
SELECT * FROM #OPTable WHERE heroName IN (@sHeroName)
在这个查询中IN 后面的括号中只有一个字符串的值 ,只是这个只看起来刚好跟'Monkey D. Luffy','Roronoa Zoro','Nami'一样而已,实际上这个三个值是一个整体的!
解决办法:使用拼接字符串的方法