MYSQL设置数据库编码

45 篇文章 0 订阅

今天在添加数据的时候中文乱码了,然后去修改了下mysql的编码格式,小问题,以前没有记录过此类问题,小记一下

先说一下mysql的8个character_set的含义:

character_set_client
主要用来设置客户端使用的字符集。

character_set_connection
主要用来设置连接数据库时的字符集,如果程序中没有指明连接数据库使用的字符集类型则按照这个字符集设置。

character_set_database
主要用来设置默认创建数据库的编码格式,如果在创建数据库时没有设置编码格式,就按照这个格式设置。

character_set_filesystem
文件系统的编码格式,把操作系统上的文件名转化成此字符集,即把 character_set_client转换character_set_filesystem, 默认binary是不做任何转换的。

character_set_results
数据库给客户端返回时使用的编码格式,如果没有指明,使用服务器默认的编码格式。

character_set_server
服务器安装时指定的默认编码格式,这个变量建议由系统自己管理,不要人为定义。

character_set_system
数据库系统使用的编码格式,这个值一直是utf8,不需要设置,它是为存储系统元数据的编码格式。

character_sets_dir
这个变量是字符集安装的目录

 

进入mysql查看编码格式:show variables like 'character_set%';

修改编码格式

再次查看编码格式:

在mysql命令行设置了只是针对此次有效,mysql下次启动的时候还是原来的

一劳永逸的办法就是修改配置文件,windows的是my.ini,linux的是my.cnf

 [mysqld] 标签下加上以下内容:

default-character-set = utf8

character_set_server = utf8

注意:如果此标签下已经存在“default-character-set=GBK”类似的内容,只需修改即可。

在 [mysql]  标签下加上一行

default-character-set = utf8

 [mysql.server]标签下加上一行

default-character-set = utf8

在 [mysqld_safe]标签下加上一行

default-character-set = utf8

在 [client]标签下加上一行

default-character-set = utf8

有些版本在[mydqld]和[client]段不支持default-character-set = utf8,请用character_set_server=utf8

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值