phpmyadmin导出sql文件乱码怎么办


本文摘自PHP中文网,作者藏色散人,侵删。

phpmyadmin导出sql文件乱码怎么办

phpMyAdmin版本是2.9.1.1

phpMyAdmin备份数据库,导出来后,在本地用sqlyog还原的时候,出现如下错误:

1

2

3

Error occured at:2009-03-03 10:09:43

Line no.:11154

Error Code: 1062 - Duplicate entry '??????' for key 2

打开sql文件看了下,会员表下的会员用户名是乱码,全都是类似于???,????的,因为现在很多程序都支持中文用户名了,而用户名又是唯一的,中文用户名变成乱码后,就出现很多相同的用户名,而我们导入这些出现乱码的数据时,前面已经有??????这个用户名了,所以下面出现第二个就报错了

如果有系统的控制权,可以用如下命令导出数据,就不会出现乱码,还原时是正常的

1

mysqldump -uroot -p --default-character-set=utf8 --set-charset --skip-opt dbname > newdbname.sql

但现在只能用phpMyAdmin导出,测试了好久,发现如果phpMyAdmin的Language为"中文-chinese simplified-gb2312"时,导出来的sql文件是gb2312的,某些表里有中文,中文为乱码,当phpMyAdmin的Laguage为"中文-chinese simplified(也就是utf8)"时,导出来的sql文件字符集是utf8的(用Notepad++查看格式,显示是UTF-8无BOM格式编码),表里的中文可以正常显示

所以,为避免导出来的文件里中文是乱码,可以从Language下拉菜单中,选择中文-chinese simplified,然后再选择导出,下载回来的sql文件中的中文就可以正常显示了。

用如下命令还原

1

mysql -uroot -p --default-character-set=utf8 newdbname < newdbname.sql

本来想把phpMyAdmin的默认Language修改为“中文-chinese simplified",但试过修改config.inc.php和libraries目录下的config.default.php都没有用,没关系了,毕竟不同人选择数据库的编码都不一样的,总是有人要重新选择一下语言,还是让它默认是“中文-chinese simplified-gb2312”吧!

猜测另外一种解决办法是,导出来的文件编码是gb2312,所以可以考虑将gb2312转换为utf8.此方法试验中。

以上就是phpmyadmin导出sql文件乱码怎么办的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

phpMyAdmin怎么修改上传文件大小

本地phpMyAdmin打不开解决方法

网站怎么搭建phpMyAdmin

phpMyAdmin怎么添加导出格式

ubuntu下如何退出phpMyAdmin

怎么在linux系统中安装配置phpMyAdmin

忘记phpMyAdmin登录密码怎么办

如何修改phpMyAdmin文件上传大小限制

phpMyAdmin访问显示空白问题的解决办法

如何将phpMyAdmin设置为禁止外网访问

更多相关阅读请进入《phpMyAdmin》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...