问题:
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"。
1. jdbc.driver =com.mysql.jdbc.Driver 2. jdbc.url =jdbc:mysql://localhost:3306/shop?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull 3. jdbc.user = root 4. jdbc.password =123456
3、未完待续,,,有了其他的解决方案,会继续增加。