我有一个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'