向数据库插入带引号的字符串

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("\"","\\\"");

忘大佬解答。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值