新手就是新手,遇到问题都不知道如何下手,看着刘敏哥在我电脑上啪啪啪了一阵,我学到了不少姿势。
总结一下:
1、我的问题:
最初是建库建表,建完库my_db后,建表student的时候发现枚举性别时create table student(sex enum('男','女'));
提示错误,1291 - Column 'sex' has duplicated value '?' in ENUM。意思好像说是字符'?'重复了,妹的,一个问号都木有啊,还好哥聪明,create table student(sex enum('男','nv'));成功,然后desc student一下,发现‘男’被显示为了‘?’,问题清楚了。
2、解决方法:
alter database my_db character set 'gbk';然后删表重新建表student就可以了。
结果就是一句话,但是来之不易:分析问题好分析,明显字符集不对,更改方法很简单,一是修改配置文件my.ini,把两个地方的字符集更改为gbk(default-character-set=gbk,character-set-server=gbk)重启,二是直接运行MySQL配置程序,两种方法均失败。三是用SET character_set_database = gbk等一系列修改,也失败。后来用alter database my_db character set 'gbk';然后删增表student,成功了。等到最后要总结的时候,发现,其实前面几种方法均可,只是有好多需要注意的点没有注意到:
a、修改字符集只对之后的操作有作用,对之前建好的库、表没有影响。我之前可能没有重新建表,导致修改无效。
b、character_set_client 、character_set_results、character_set_connection 三个保持一致的字符集,这也就是为什么SET character_set_database = gbk可能会没有生效的原因,因为没有始终考虑到字符集的一致性。
操作过程中查看字符集可以使用show variables like '%char%';查看已经建好的表所使用的字符集也可以用管理工具navicat,非常方便,使用navicat时需要注意刷新。
另外,回顾了一下,发现很不透彻,努力了半天,总结了一下文章,希望以后常看
几篇文章:很好
很有扫盲和进阶价值,提到了set是临时修改:
MySQL字符集乱码总结 http://blog.csdn.net/ithomer/article/details/5130789