咨询热线:4006-75-4006
售前:9:00-23:30 备案:9:00-18:00 技术:7*24h
今天碰到phpmyadmin导入sql文件,中文内容乱码导致导入出错问题,已解决,总结出phpmyadmin的编码设置问题如下:
一、phpmyadmin设置新建数据库的默认编码为gbk或utf8编码的方法
1.先查看本mysql的各项charset设置,运行sql查询语句:
show variables like 'character%';
查询结果中:
character_set_database:代表当前所在数据库的编码,这里是latin1;
character_set_server代表默认的新建数据库编码,还是latin1;
也就是说,我的当前所在数据库编码是lantin1,而如果我新建一个数据库,默认编码是latin1。
2.根据character_set_database和character_set_server的值,我们就好办了。运行以下两条sql语句,即可设置完毕:
set character_set_server=utf8; //设置默认新建数据库编码为utf8
alter database testdb character set utf8; //更改现有数据库编码
注意:“set character_set_server=uft8”只对当前连接或者查询有效,果想新建数据库,请将create database语句写在同一查询中,否则无效。
若想永久生效,将“character_set_server = utf8”写入mysql的配置文件/etc/my.cnf即可。
二、phpmyadmin导入数据库时gbk或utf8编码的设置(解决导入数据库中文乱码问题)
1.首先确保导入的sql文件中的中文不是乱码,此sql文件可以是utf8编码也可以是gb2312编码;
2.在sql文件的最开头添加set names utf8或者gb2312;(必须与你文件的编码相同,如果你想导入后是utf8,你的文件编码就要是utf8,如果想导入后是gbk/gb2312,你的文件编码就要是gbk/gb2312);
3.通过phpmyadmin导入界面直接导入即可;
4.文件的字符集,mysql字符集,mysql连接校对等几?字符集设置可以不用管,比如我这里mysql字符集,mysql连接校对分别是latin1和utf8_general_ci,不影响我的导入后的字符集和编码。