加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 数据库 > MsSql > 正文

当变量包含单引号时,SQL动态查询字符串中断

发布时间:2020-05-23 14:37:24 所属栏目:MsSql 来源:互联网
导读:我有一个SQL查询字符串,如下所示: DECLARE @sql varchar(max)SET @sql = INSERT INTO + @tempTable1 + SELECT 0 as Type1, 0 as Type2, + + @name + as CompanyName +

我有一个SQL查询字符串,如下所示:

DECLARE @sql varchar(max)
SET @sql = ' INSERT INTO ' + @tempTable1 + 
           ' SELECT 0 as Type1,0 as Type2,' + 
             '''' + @name + ''' as CompanyName ' + 
           ' FROM #tempTable2 tt2'

查询运行正常,除了包含单个引号的两个名称(例如:Pete’s Corner).当这些名称中的任一个成为查询的一部分时,它会中断查询字符串.我认为最简单的做法是替换像这样的单引号(@name,”’,”),但它不起作用,因为我已经在一个字符串中,所以它影响了其余的该声明.不幸的是,改变表本身不是一个选择.

如何更换或删除这些单引号?

另外:我很抱歉,我没有包含通过连接实际上从另一个数据库表填充@name的部分,所以在创建字符串之前设置@name的值我认为对我来说是困难的.

解决方法

我认为这应该做到:
DECLARE @sql varchar(max)
SET @sql = ' INSERT INTO ' + @tempTable1 + 
       ' SELECT 0 as Type1,' + ''''+
         replace( @name,'''','''''')+''''+' as CompanyName  
       FROM #tempTable2 tt2'

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读