exec sp_executesql带单引号的问题

ttyrone 2014-11-19 04:29:15

use northwind
exec sp_executesql N'select * from customers where customerid in (''ALFKI'',''ANATR'')'

这样执行没问题

use northwind
exec sp_executesql N'select * from customers where customerid in (@customerid)'
,N'@customerid varchar(8000)',@customerid='ALFKI'',''ANATR'

这样就查不出数据来,请问这是怎么回事
...全文
406 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
jxwangjm 2014-11-19
  • 打赏
  • 举报
回复
你可以试一下用char(39)代替', 比如set varStr1='abc'+char(39)+'ef',将会得到abc'ef
Tiger_Zhao 2014-11-19
  • 打赏
  • 举报
回复
#4:
我手里拿着一张纸,上面写着“两张纸”。
问:我手里一共有几张纸?
Tiger_Zhao 2014-11-19
  • 打赏
  • 举报
回复
不定个数直接拼SQL吧
DECLARE @sql nvarchar(max)
DECLARE @customerid nvarchar(max)
SET @customerid=N'''ALFKI'',''ANATR'''
SET @sql = N'select * from customers where customerid in ('+@customerid+N')'
--PRINT @sql
exec sp_executesql @sql
还在加载中灬 2014-11-19
  • 打赏
  • 举报
回复
当然查不出来啦,这样本身就有语法问题了 把你的动态执行拿出来看,你就明白了 它等价于
DECLARE @customerid VARCHAR(8000)
SET @customerid='ALFKI'',''ANATR'
select * from customers where customerid in (@customerid)
中国风 2014-11-19
  • 打赏
  • 举报
回复
不支持in()--直接传参多个值 只能这样用
EXEC sp_executesql N'SELECT top 2 * FROM sys.all_objects where Name IN(@Names)',N'@Names NVARCHAR(200)',@Names='sysrscols'
ttyrone 2014-11-19
  • 打赏
  • 举报
回复
引用 1 楼 Tiger_Zhao 的回复:
前一句IN的范围有两个值,分别是 ALFKIANATR。 后一句IN的范围只有一个值,是 ALFDI','ANATR(单引号是字符串值内容)。 有多少个值就要定义多少个参数
exec sp_executesql N'select * from customers where customerid in (@customerid1,@customerid2)',
                   N'@customerid1 varchar(8000),@customerid2 varchar(8000)',
                   @customerid1='ALFKI',
                   @customerid2='ANATR'
后一句IN的范围只有一个值,是 ALFDI','ANATR(单引号是字符串值内容)。 值是ALFDI','ANATR,然后会在两端自动插入单引号,那应该就是两个值in ('ALFDI','ANATR')吧
中国风 2014-11-19
  • 打赏
  • 举报
回复
用字符加减
  DECLARE @Sql NVARCHAR(max)
  SET @Sql=N'select * from customers where customerid in ('''+'ALFKI'',''ANATR'+''')'
  exec sp_executesql @Sql
ttyrone 2014-11-19
  • 打赏
  • 举报
回复
引用 1 楼 Tiger_Zhao 的回复:
前一句IN的范围有两个值,分别是 ALFKIANATR。 后一句IN的范围只有一个值,是 ALFDI','ANATR(单引号是字符串值内容)。 有多少个值就要定义多少个参数
exec sp_executesql N'select * from customers where customerid in (@customerid1,@customerid2)',
                   N'@customerid1 varchar(8000),@customerid2 varchar(8000)',
                   @customerid1='ALFKI',
                   @customerid2='ANATR'
额,因为这个@customerid1是不定的,没法确定要定义几个参数
Tiger_Zhao 2014-11-19
  • 打赏
  • 举报
回复
前一句IN的范围有两个值,分别是 ALFKIANATR
后一句IN的范围只有一个值,是 ALFDI','ANATR(单引号是字符串值内容)。
有多少个值就要定义多少个参数
exec sp_executesql N'select * from customers where customerid in (@customerid1,@customerid2)',
N'@customerid1 varchar(8000),@customerid2 varchar(8000)',
@customerid1='ALFKI',
@customerid2='ANATR'
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧