用mysql 排序规则导致的 大小写问题

本文通过一个实际案例解析了MySQL中字符集与排序规则的重要性。详细介绍了utf8_general_ci与utf8_bin的区别,前者不区分大小写,速度快;后者区分大小写,将字符串作为二进制数据存储。并提供了修改表字符集和排序规则的方法。

一直以为mysql不区分大小写,直到今天遇到一个mysql字符集的问题,记录下:

我在测试过程中发现当用户名输入为大写时,后端返回的数据正常,但是当用户名输入为小写时,数据就返回为空。一层层往上找时,发现在建表过程中有两张权限表,不知被哪个老哥设置了排序规则为 utf8_bin,结果导致了上面的问题。

趁着这个机会,了解了一波mysql 的排序规则,主要就是:

1、utf8_general_ci 不区分大小写,utf8_general_cs 区分大小写

2、utf8_bin 区分大小写 将字符串每个字符串用二进制数据编译存储

3、ci是 case insensitive, 即 "大小写不敏感", cs是 case sensitive, 即 "大小写敏感"

4、utf8_general_ci速度比较快,一般选用utf8_general_ci就可以了

 

修改表的字符集和排序规则:

ALTER TABLE 表名 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值