免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3377 | 回复: 6
打印 上一主题 下一主题

【已解决】mysqldump导出gbk字符再恢复后不正确 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-11-06 16:18 |只看该作者 |倒序浏览
本帖最后由 byrcc 于 2012-11-14 19:50 编辑

今天做主从一致检查,发现不同的数据,手动通过mysqldump同步一次,发现结果不正确。myqsldump和导入时mysql命令都使用--default-character-set=utf8选项。如下图,第一张图是源表,第二张图是使用dump文件导入到的另一个表。这两个表字符集为gbk,从显示来看,估计找个字段包含非gbk编码的字符。为什么数据会不一样?是否有人也遇到过同样的问题?

论坛徽章:
0
2 [报告]
发表于 2012-11-12 13:00 |只看该作者
导入导出你都使用gbk不行么

论坛徽章:
0
3 [报告]
发表于 2012-11-14 15:04 |只看该作者
本帖最后由 byrcc 于 2012-11-14 15:35 编辑

回复 2# du_liang
刚测试了一下,使用gbk导出再导入就没问题了。。好奇怪,按理说gbk编码的表用utf8导出再导入不该有问题呀?

查了下手册,mysqldump没有指定default-character-set的话,默认使用utf8。这样的话,应该是他这个gbk的字段中,包含了非法的gbk字符,才导致gbk到utf8转换出错

论坛徽章:
0
4 [报告]
发表于 2012-11-14 19:50 |只看该作者
又测试了一下,确认那个字段中有非gbk的字符,导致mysqldump时,如果不指定表的gbk编码,则发生gbk到utf8的转码,非法字符转码失败,导致导出的数据有问题

论坛徽章:
0
5 [报告]
发表于 2012-11-14 21:56 |只看该作者
回复 4# byrcc

如果不指定表的gbk编码,则发生gbk到utf8的转码,

你指定一下就可以了?  导入时指定?


   

论坛徽章:
1
2015亚冠之本尤德科
日期:2015-06-05 17:25:48
6 [报告]
发表于 2012-11-15 09:43 |只看该作者
导出的文件,使用命令看一下。

file -i filename

然后导进去的时候使用

如果filename是utf8
就用如下命令:
mysql --default-character-set=utf8 <filename

如果是gbk
就用如下命令:

mysql --default-character-set=gbk <filename


不可能有错,我都导入不知道多少遍,全部试线上环境

论坛徽章:
0
7 [报告]
发表于 2012-11-22 15:02 |只看该作者
回复 6# zhangshengdong
我这里的情况是,gbk编码的表中,有个字段包含非GBK字符,就是™这个,它在表中存的十六进制值是E284A2,你可以试试。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP