MySQL数据库‘反斜杠\’ ,‘单引号‘’,‘双引号“’,‘null’无法存储

10 篇文章 0 订阅
8 篇文章 0 订阅

MySQL数据库‘反斜杠\’ ,‘单引号’'’,‘双引号""’,‘null’无法存储,\ ’ " null 字符被过滤

问题原因:
在mysql中这些字符被当做成了转义字符(单引号,双引号,反斜杠,null);
比如我们在写SQL语句时不管是查询修改还是新增,比如是一些文字或者数字都可以正常的进行查询和新增等,但是如果一旦里边包含了特殊字符,比如说要插入“今天下雨了\今天没下雨” 这里的反斜杠会被当成转义字符稀释掉,到了数据库内就是“今天下雨了今天没下雨”,这里类似于过滤掉了一样;
解决方式:
PHP addcslashes()函数
该函数要求PHP版本4+

addcslashes()	//函数返回在预定义的字符前添加反斜杠的字符串。
				//提示:该函数可用于为存储在数据库中的字符串以及数据库查询语句准备合适的字符串。

预定义字符是:

单引号(')
双引号(")
反斜杠(\)
NULL

该函数会对这些预定义字符前添加反斜杠\

$name = '小红\小蓝';
$name = addcslashes($name);
//这里的name值为 小红\\小蓝
//在数据库存储时第一个 \ 被当做转义字符

这个时候存储就不会有问题了;
将插入到mysql内的字符进行转义的实质是:将php中的特殊字符如(‘’,“”,, null)插入到数据库。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值