Mysql数据库大小写问题

SELECT * FROM USER where name = ‘aaa’;
SELECT * FROM USER where name = ‘AAA’;
以上两条sql执行结果是一样的。
以上两条语句的查询结果是一样的
以上两条sql语句的执行结果是一样的,发现Mysql有时是不区分大小写的。
如何区分大小写以下是三种方式,本人亲测
1:建库的时候排序规则选择utf8_bin,然后这个库下面建的表默认是区分大小写的。

utf8_bin:将字符串中的每一个字符用二进制数据存储,区分大小写。
utf8_genera_ci:不区分大小写,ci为case insensitive的缩写,即大小写不敏感。
utf8_general_cs:区分大小写,cs为case sensitive的缩写,即大小写敏感。建表工具里边没有,也不建议使用。
在这里插入图片描述

2:建表的时候每个字段后加上BINARY 属性后,该字段区分大小写
CREATE TABLE T(
A VARCHAR(10) BINARY
);

3:在需要的字段上做修改
ALTER TABLE user modify COLUMN AGE VARCHAR(255) BINARY

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值