1、字符串带有单引号
①用双引号包裹字符串
INSERT INTO TableName(ColumnName)VALUES("Hello'");
②用单引号包裹字符串,字符串中的单引号通过加\转义
INSERT INTO TableName(ColumnName)VALUES('Hello\'');
③用单引号包裹字符串,字符串中的单引号前再多加一个单引号
INSERT INTO TableName(ColumnName)VALUES('Hello''');
2、字符串带有双引号
和单引号类似
①用单引号包裹字符串
INSERT INTO TableName(ColumnName)VALUES('Hello"');
②用双引号包裹字符串,字符串中的双引号通过加\转义
INSERT INTO TableName(ColumnName)VALUES("Hello\"");
③用双引号包裹字符串,字符串中的双引号前再多加一个双引号
INSERT INTO TableName(ColumnName)VALUES("Hello""");
3、字符串既带有双引号又带有单引号
①用单引号包裹字符串
INSERT INTO TableName(ColumnName)VALUES('Hello"\'');
等等等等…
我想应该理解了。
4、通过PHP,Java等来更新数据库
前面的都是直接操作数据库,而通过其他语言来更新数据库的时候,就需要用到多次转义。
但是如果是用双引号包裹包含单引号的字符串或者用单引号包裹包含双引号的字符串,似乎是不用转义的。
以下只是我的实践结果加上我个人的猜想(瞎扯)
比如,用PHP来更新数据库
//在PHP中
s= s.replaceAll("\"","\\\"")
可以理解为是间接地操作数据库,所以需要两次转义。
\\\" -> \"
比如,在Android中,访问PHP文件来更新数据库
//在Android的Java文件中
s = s.replaceAll("\"","\\\\\\\"");
可以理解为是间间接地操作数据库,就需要三次转义
\\\\\\\" -> \\\" -> \"
5、其他问题
在实际coding中,我需要通过jdbc来操作数据库,当查询语句中既带有单引号又带有双引号,且字符串有双引号包裹时,我需要这样做才能成功更新数据库。
s= s.replaceAll("\"","\"\"");
而不能
s= s.replaceAll("\"","\\\"");
忘大佬解答。