当变量包含单引号时,SQL动态查询字符串中断
发布时间:2020-12-12 08:31:14 所属栏目:MsSql教程 来源:网络整理
导读:我有一个SQL查询字符串,如下所示: DECLARE @sql varchar(max)SET @sql = ' INSERT INTO ' + @tempTable1 + ' SELECT 0 as Type1,0 as Type2,' + '''' + @name + ''' as CompanyName ' + ' FROM #tempTable2 tt2' 查询运行正常,除了包含单个引号的两个名称(例
我有一个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' (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |