设定mysql的默认字符集
admin
2023-05-20 09:42:32
0

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字符集呢?以下列出两种:


  1. 修改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转换过程中会丢失数据,并不可还原。

相关内容

热门资讯

国家信息光电子创新中心成功研发... 5月15日消息,据“中国光谷”公众号,国家信息光电子创新中心(NOEIC)近日成功自主研发了一款超宽...
特朗普称如果伊朗不迅速行动,“... 新华社华盛顿5月17日电(记者徐剑梅 黄强)美国总统特朗普17日在社交媒体发文称,如果伊朗不迅速行动...
柳州5.2级地震致楼房倒塌,店... 据中国地震台网消息,5月18日00时21分在广西柳州市柳南区发生5.2级地震,震源深度8千米。有网友...
“华南第一商圈”再升级!全国首... 5月16日,“万兆AI惠商,联通美好未来”2026年517电信日暨中国联通品牌与产品广东宣传推广会在...
原创 3... 如果今年618你手里预算在3000多元,又特别看重拍照,我反而不建议只盯着那些刚发布、热度很高的新机...
苹果首款折叠屏iPhone U... 快科技5月17日消息,今年4月曾有消息称,苹果首款折叠屏手机iPhoneUltra(iPhone F...
广西柳州发生5.2级地震,南宁... 据中国地震台网正式测定,5月18日0时21分在广西柳州市柳南区发生5.2级地震,震源深度8公里,震中...
购药新规落地!多地药房称买“减... 5月17日消息,近日有消息称,自5月15日起,司美格鲁肽、替尔泊肽等GLP-1药物均需要凭有效期内的...
苹果深夜“放价”:iPhone... 来源:环球网 【环球网科技综合报道】5月15日消息,苹果在深夜毫无预警地打响了一轮价格战,iPho...
原创 从... 进入2026年5月下旬,手机圈即将迎来全年最密集的新品发布窗口。 从今天开始到7月下旬,短短两个月时...