前提:创建table student,语句见文末。
msyql的大小写不敏感情况;
1.sql语句关键字不敏感,例如 select 1
和SeLeCt 1
,执行结果完全相同;
2.sql语句表名、字段名不敏感,例如 select * from student where id = 1
和 select * 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