php插入数据库乱码怎么解决,php向数据库插入数据出现乱码问题

php向数据库插入数据出现乱码的解决办法:首先将数据库的编码设为utf8;然后判断要插入数据库的文本编码方式;最后通过switch语句实现数据判断插入即可。

3196f7b82443932b9145623f915da9be.png

php向数据库插入数据出现乱码问题

一般插入到数据库的数据乱码都是编码的问题,可以在插入数据库前查看下内容的编码方式,如果和数据库用的编码方式(如:utf-8)一样就执行插入操作,不一样就进行转码。

先判断你要插入数据库的文本的编码方式,是utf-8就插入,不是的话要转为utf-8之后再插入:$e=mb_detect_encoding($text, array('UTF-8', 'GBK', 'gb2312'));

switch($e){

case 'UTF-8' : //如果是utf8编码就直接插入数据库

break;

case 'GBK': //如果是gbk编码就转换为utf-8之后再插入数据库

iconv("GBK", "UTF-8",$data) ;

break;

case 'GB2312': //如果是GB2312编码就转换为utf-8之后再插入数据库

iconv("GB2312", "UTF-8",$data) ;

break;

}

本以为程序中的编码和数据库用的编码保持一致就不会出现乱码了,可是,插入数据库的数据还是有乱码出现,排除了编码不一致之后,就想到可能是使用php连接mysql时没有设定mysql编码的缘故,果然,在连接数据库之后将数据库的编码也设为utf8之后再进行数据库插入操作就没有乱码了。

代码如下:$this->conn = mysqli_connect($db['default']['hostname'], $db['default']['username'], $db['default']['password'], $db['default']['dbname']) or die('Connect error!'); //连接到数据库

mysqli_set_charset($this->conn, 'utf8'); //此处不能用utf-8

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值