mysql字符集大小写_【MySQL运维】MySQL字符集、校对规则与大小写问题

一、字符集介绍

字符集用来定义数据在数据库中的格式,在MySQL中默认的字符集是latin1,其它常见的字符集有UTF8、UTF8MB4、GBK、ASCCI等,每种字符集有一个与该字符集对应的默认校对规则,以字符集名开始,以_ci(不区分字段数据大小写)、_cs(区分字段数据大小写)或_bin(二进制,区分字段数据大小写)结束,比如utf8字符集默认校对规则是utf8_general_ci。字符集和校对规则根据级别分为服务器级、数据库级、表级和会话级,低级默认继承上级的设置。

二、查看MySQL所支持的字符集以及当前所使用的字符集

mysql > show character set; #查看当前服务支持的字符集

mysql > show variables like "character%";

二、修改字符集解决MySQL中文乱码的办法

方法1:使用set names语句临时修改字符集

mysql > show create database databasename

mysql > show create table tablename

mysql > set names utf8mb4;

方法2:导入数据库文件时指定默认字符集

mysql -uroot -p --default-character-set=latin1 testdata

方法3:在创建数据库或者表的时候指定字符集和校对规则。这样数据库里的表就不用单独设置了,会继承库的设置

mysql > CREATTE DATABASE databasename DEFAULT CHARACTER SET UTF8 COLLATE utf8_general_ci; #设置字符集的写法有很多种

方法4:在my.cnf配置文件里指定默认字符集(永久生效,可以把当前全局设置一起修改避免重启)

vi /etc/my.cnf

[client] #客户端字符集

default-character-set=utf8mb4

[mysqld] #服务端字符集

# default-character-set=latin1 #5.1之前版本

character-set-server=utf8mb4 #utf8mb4是utf8的升级

skip-character-set-client-handshake=1 #客户端也使用服务端的字符集,不用再单独为客户端做设置

mysql > set global character_set_server=utf8mb4; #全局临时设置

保证不乱码的主要思想:客户端与服务器端字符集统一,库表字符集统一,浏览器字符集统一,程序字符集统一

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值