msyql的大小写不敏感问题和collate属性

前提:创建table student,语句见文末。

msyql的大小写不敏感情况;
1.sql语句关键字不敏感,例如 select 1SeLeCt 1,执行结果完全相同;

2.sql语句表名、字段名不敏感,例如 select * from student where id = 1select * from Student where ID = 1 完全相同;

3.sql语句的条件值不敏感,例如select * from student where name ="cauchy6317"select * from student where name ="CauCHy6317" 完全相同;

对于第1和第2种情况,其实是mysql的一个优点,关键字和表名、字段名等大小不敏感,提高了工作效率,不用每个单词的大小写都拼写无误。
但是对于第3种情况,就要具体业务具体看待了。在业务对大小写敏感时,比如某个设备表的设备型号,档案表的档案号(举例而已,莫要抬杠),
那么在对于大小写敏感时,该如何写查询?下面介绍两种方法:
1.使用binary:
select * from student where binary name = "cauchy6317"; binary是二进制的意思,使用bianry以后 name的字段值和条件值的比较规则是 byte by byte(字节比较),没有使用binary时,比较规则是 character by character(字符比较)。
2. 修改name字段的collate,mysql有很多校验规则,有的校验规则是大小不敏感,有的校验规则是大小写敏感的。从sql的创建语句可以看到name字段是大小写不敏感的。“utf8mb4_0900_ai_ci ” utf8mb4是字符集,0900是字符集的比较算法,ai全称accent insensitive,音节不敏感,比如汉语拼音的ā á ǎ à,查询a会查出所有声调,ci全称character insensitive,字符不敏感。
修改语句:alter table student modify column name varchar(255) character set utf8mb4 collate utf8mb4_0900_as_cs;
修改完查询表结构:show create table student;

第一种方法治标,第二种方法治本。
字符集指的是一种从二进制编码到某类字符符号的映射。校对规则则是指某种字符集下的排序和比较规则。MySQL中每一种字符集都会对应一系列的校对规则。每一种字符集都会有个默认的校对规则。

MySQL采用的是类似继承的方式指定字符集的默认值,每个数据库以及每张数据表都有自己的默认值,它们逐层继承。比如:某个库中所有表的默认字符集将是该数据库所指定的字符集(这些表在没有指定字符集的情况下,才会采用默认字符集)

sql:CREATE TABLE student (
id int(5) NOT NULL AUTO_INCREMENT,
name varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL,
height varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL,
birth date DEFAULT NULL,
PRIMARY KEY (id),
KEY studentName (name)
) ENGINE=InnoDB AUTO_INCREMENT=550 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
参考网址:https://stackoverflow.com/questions/1294117/how-to-change-collation-of-database-table-column
https://dev.mysql.com/doc/mysql-g11n-excerpt/8.0/en/charset-collations.html

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值