mysql乱码排查

查询当前服务器的字符集:show variables like 'character_set_server';
查询当前服务器的校对规则:show variable like 'collation_server';
显示当前数据库的字符集:show variables like 'character_set_database';
显示当前数据库的校对规则: show variables like 'collation_database';
显示表的字符集和校对规则:show create table table_name;


上面是数据保存的字符集和校队规则,还存在客户端和服务器之间交互的字符集和校队规则的设置。


character_set_client, character_set_connection, character_set_results.分别代表客户端,连接和返回结果的字符集.


set names ***; 设置连接的字符集和校对规则。


另外一个更简便的方法,是在my.cnf中设置以下语句:
[mysql]
default-character-set=gbk


将latin1字符集的数据库修改成gbk字符集的数据库的过程
(1) 导出表结构 mysqldump -uroot -p --default-character-set=gbk -d databasename > createtab.sql
--default-character-set=gbk 表示设置以什么字符集连接
(2) 手工修改createtab.sql中表结构定义中的字符集为新的字符集
(3) 确保记录不再更新,导出所有记录
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename > data.sql
(4) 打开data.sql, 将set names latin1 修改成 set names gbk
(5) 使用新的字符集创建新的数据库
    create database databasename default charset gbk;
(6) 创建表,执行createtab.sql
mysql -uroot -p databasename < createtab.sql;
(7) 导入数据
    mysql -uroot -p databasename < data.sql;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值