mysql> show global variables like '%charac%'; --查看当前mysql采用的字符集
mysql>show global variables like '%server%'; --查看当前服务端全局字符集
+----------------------+--------------------+
| Variable_name | Value |
+----------------------+--------------------+
| character_set_server | latin1 |
| collation_server | latin1_swedish_ci
+----------------------+--------------------+
2 rows in set (0.00 sec)
如何修改为我们熟悉的UTF8字符集呢?以下列出两种:
修改my.cnf文件,需重启服务,长期有效
在server下添加两行:
character_set_server=utf8
collation_server=utf8_general_ci
2.修改mysql变量,不用重启,建立新会话时生效,但重启后失效.
mysql> set global character_set_server=utf8; --修改当前字符集为utf8,不加global 却仅对当前会话有效.
3.在客户端指定要使用的字符集
mysql>set character-set_results=gbk; --在客户端设定
4.设定当前会话使用的字符集:
mysql>set names gbk; --设定当前会话使用gbk字符集.
5.mysql>set character set gbk; --设定当前系统的变量为GBK
mysql>set charset gbk; --与上句相同
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
mysql>show create table 表名; --查看建表时使用的字符集
mysql> alter database 数据库名 character set utf8; --更改数据库默认字符集utf8,更新后新建表格将采用新的字符集
mysql> alter table 表名 character set utf8; --更改表格默认字符集为utf8,更新后添加的列将采用新的字符集
mysql> show full fields from 表名; --查看数据表的各列信息,包括列的字符集和可操作权限等
mysql>alter table 表名 modify 字段名 字段类型 CHARACTER SET utf8, modify 字段名 字段类型 CHARACTER SET utf8; --更新字段字符集属性为utf8,我原来的为latin1,不能插入中文
-------------------------------------------------------------------------------------------------------------------------------------- 练练手 --------------------------------------------------------------
mysql>create database test2 charset gbk; --建立test2数据库时指定字符集为GBK,此后在此库下建立新表格,默认采用GKB字符集;
mysql>alter database test2 charset utf8; --更改默认字符集为utf8;更改后在此库下新建表格采用utf8字符集。
mysql>show create database tests; --查询新建数据时的信息
mysql> create table ab (id char(10)) charset gbk; --用gbk字符集新建一个表ab
mysql>alter table ab charset utf8; --更改ab默认字符集为utf8
mysql>create table bd(id char(10) charset gbk); --建表时指定id字段用gbk字符集
mysql>show create table ab; --查询建ab表时用的信息。
更改字符集需谨慎!
修改表和列的字符集时要考虑字符集的兼容,不然在mysql转换过程中会丢失数据,并不可还原。