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

前端之家收集整理的这篇文章主要介绍了当变量包含单引号时,SQL动态查询字符串中断前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个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的值我认为对我来说是困难的.

解决方法

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

猜你在找的MsSQL相关文章