java与mysql的连接字符串,指明字符集的写法

问题症状:
1,用mysql-front等客户端编写的sql语句向mysql插入中文字符没有任何问题。
2,用 注明了连接方式(包括host,user,passward,database,charset)的python向mysql插入中文字符没有问题。
3,检查了eclipse和系统的默认字符集,都是utf-8,没有问题。
可是,用java向mysql插入中文字符就是有乱码。倒腾了快一天。。。

问题排查:
检查mysql端的用show variables like '%char%' 得到如下结果:
"character_set_client","utf8"
"character_set_connection","utf8"
"character_set_database","utf8"
"character_set_filesystem","binary"
"character_set_results","utf8"
"character_set_server","latin1"
"character_set_system","utf8"
这说明服务器上mysql默认的server端的编码方式为l atin1, 尽管我需要操作的数据库实例的大多数表的大多数字段都已经写成了ut f-8,但使用jdbc的默认连接方式仍然会出现 乱码问题。

解决方案:
在java的连接字符串中写明需要的编码方式,
例如,连接字符串写成:

jdbc:mysql://192.9.200.41:3306/mydbinstance?characterEncoding=utf-8


总结:

如果遇到乱码问题可以从三个方面检查

a, eclipse和java的默认编码格式,可以通过System.out.println(Charset.defaultCharset());判断。

b,检查mysql表中字段使用的编码方式。

c,连接字符串中的编码方式。



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值