小心 ------ SQL SERVER (1)

查询1:

小心 ------ SQL SERVER (1)

查询2:

小心 ------ SQL SERVER (1)

查询3:

小心 ------ SQL SERVER (1)

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'一样而已,实际上这个三个值是一个整体的!

解决办法:使用拼接字符串的方法

小心 ------ SQL SERVER (1)

相关文章:

  • 2021-12-02
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-21
  • 2021-09-23
  • 2021-12-29
  • 2022-12-23
猜你喜欢
  • 2021-05-14
  • 2021-04-01
  • 2021-06-15
  • 2021-08-17
  • 2021-05-26
  • 2022-12-23
  • 2021-09-29
相关资源
相似解决方案