mysql中文乱码解决方法

问题:

   mysql中文乱码是个经常遇到的问题。

成因:

   成因是字符转换编码格式时,不能完全转成功就会乱码。utf-8的字符集比GBK更强大,能表示的内容更多。例如如果程序用的是utf-8编码,而数据库用的是gbk编码,在存入数据库时就会因为某些字符在utf-8中有对应的编码,而在gbk里没有对应的编码而出现乱码。(目前理解是这样,如果不对,欢迎拍砖~)

知识扩展:

   常用编码格式有UTF-8,GBK,GB2312等等。其中UTF-8兼容世界上所有字符。

   UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。

   GBK全称《汉字内码扩展规范》(GBK即“国标”、“扩展”汉语拼音的第一个字母,英文名称:Chinese Internal Code Specification)。

   GBK与UTF8的区别是什么呢?更多戳这里

   UTF8编码格式很强大,支持所有国家的语言,正是因为它的强大,才会导致它占用的空间大小要比GBK大,对于网站打开速度而言,也是有一定影响的。

   GBK编码格式,它的功能少,仅限于中文字符,当然它所占用的空间大小会随着它的功能而减少,打开网页的速度比较快。


解决方案:


1、检查数据库、数据表、数据字段的编码格式,是否为utf-8.不是的改成utf-8.

  (1)通过客户端检查就很简单了。 

   

 

   

  (2)如何通过命令行修改,请戳这里

2、检查连接数据库的编码格式是否设为了UTF-8,在连接字符串后加上如下字符串"?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull"

jdbc.driver =com.mysql.jdbc.Driver
jdbc.url =jdbc:mysql://localhost:3306/shop?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull
jdbc.user = root
jdbc.password =123456

3、未完待续,,,有了其他的解决方案,会继续增加。





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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值