我试图将一些文本数据插入到SQL Server 9中的表中。
文本中包含了一个引用。
我怎么逃脱呢?
我尝试使用两个单引号,但它给我带来了一些错误。
如。插入my_table值('hi, my name' s tim.');
我试图将一些文本数据插入到SQL Server 9中的表中。
文本中包含了一个引用。
我怎么逃脱呢?
我尝试使用两个单引号,但它给我带来了一些错误。
如。插入my_table值('hi, my name' s tim.');
当前回答
我们中的许多人都知道,转义单引号的流行方法是像下面这样轻松地将它们重复。
PRINT 'It''s me, Arul.';
我们将研究其他一些转义单引号的替代方法。
1. UNICODE字符
39是单引号的UNICODE字符。我们可以像下面这样使用它。
PRINT 'Hi,it'+CHAR(39)+'s Arul.';
PRINT 'Helo,it'+NCHAR(39)+'s Arul.';
2. QUOTED_IDENTIFIER
另一个简单且最佳的替代解决方案是使用QUOTED_IDENTIFIER。 当QUOTED_IDENTIFIER设置为OFF时,字符串可以用双引号括起来。 在这个场景中,我们不需要转义单引号。 所以,这种方法在使用很多带单引号的字符串值时非常有用。 当使用这么多行INSERT/UPDATE脚本(其中列值有单引号)时,这将非常有帮助。
SET QUOTED_IDENTIFIER OFF;
PRINT "It's Arul."
SET QUOTED_IDENTIFIER ON;
结论
上述方法适用于AZURE和On Premises。
其他回答
只要在要插入的任何东西之前插入一个'。它将像sqlServer中的转义字符
例子: 当你有场作为,我很好。 你可以: UPDATE my_table SET row ='I' m fine.';
下面的语法将只转义一个引号:
SELECT ''''
结果将是一个单引号。对于创建动态SQL:)可能非常有帮助。
这应该可以
DECLARE @singleQuote CHAR
SET @singleQuote = CHAR(39)
insert into my_table values('hi, my name'+ @singleQuote +'s tim.')
如何:
insert into my_table values('hi, my name' + char(39) + 's tim.')
有两种方法可以解决这个问题:
对于',你可以简单地在字符串中加倍它,例如。 选择'I' m happy '——将得到:I'm happy
对于任何你不确定的字符:在sql server中,你可以通过选择unicode(':')来获得任何字符的unicode(你保留这个数字)
在这种情况下你还可以选择I +nchar(39)+ m happy