show variables like 'character_set_%'; //可以查看当前mysql环境的字符编码;
| character_set_client | utf8
| character_set_connection | utf8
| character_set_database | utf8 //一般是因为这个编码错了,
| character_set_filesystem | binary
| character_set_results | utf8
| character_set_server | utf8
| character_set_system | utf8
status; //可以查看当前数据库的编码情况,比如进入了某个数据库,然后用这个命令,就可以查看当前的数据库的字符编码了;
我的做法是在创建这个db时就给它显式的制定一个字符编码集,如下:
create database mydb default charset utf8; //当然也可以改当前的字符编码集,set character_set_database=utf8;
注意:保证character_set_database和character_set_client、character_set_connection的字符集是一致的,不然会导致乱码;
还有其他中通过改配置的方式解决这个问题,见:
http://www.cnblogs.com/Logen/p/3562215.html