面试官:MySQL中COLLATE是用来做什么的?

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 面试官:MySQL中COLLATE是用来做什么的?

文章目录



前言


MySQL中凡是涉及到字符类型比较或排序的地方,都会和COLLATE有关


⛳️ 1.COLLATE介绍


COLLATE即使校验规则, 会影响到 ORDER BY 语句的顺序,

会影响到 WHERE 条件中大于小于号筛选出来的结果,

会影响DISTINCT、GROUP BY、HAVING语句的查询结果。

另外,mysql 建索引的时候,如果索引列是字符类型,

也会影响索引创建,只不过这种影响我们感知不到。

总之,凡是涉及到字符类型比较或排序的地方,都会和 COLLATE 有关


image.png

在mysql中执行show create table 指令,可以看到一张表的建表语句

image.png

image.png

所谓所谓utf8_unicode_ci,其实是用来排序的规则。

对于mysql中那些字符类型的列,

如VARCHAR,CHAR,TEXT类型的列,

都需要有一个COLLATE类型来告知mysql如何对该列进行排序和比较。


⛳️ 2.COLLATE的区别


COLLATE 通常是和数据编码(CHARSET )相关的 ,

一般来说每种 CHARSET 都有多种它所支持的 COLLATE,

并且每种 CHARSET 都指定一种 COLLATE 为默认值。

latin1 编码的默认 COLLATE 为 latin1_swedish_ci

GBK 编码的默认 COLLATE 为 gbk_chinese_ci

utf8mb4 编码的默认值为 utf8mb4_general_ci

另外需要注意的一点是,

从 mysql 8.0 开始,

mysql 默认的 CHARSET 已经不再是 Latin1 了,

改为了 utf8mb4,并且默认的 COLLATE 也改为了 utf8mb4_0900_ai_ci


mysql> show charset where charset in (‘gbk’,‘utf8mb4’,‘latin1’);

image.png

⛳️ 3.COLLATE的影响


🌈 3.1 大小写影响


create table case_bin_test (word VARCHAR(10));
INSERT INTO case_bin_test VALUES (‘Frank’),(‘Google’),(‘froogle’),(‘flickr’),(‘FlicKr’);

image.png

mysql查询默认是不区分大小写的,如下所示

image.png

如果想区分大小写,则要加binary,如下所示

image.png

image.png

🌈 3.2 排序影响

MySQL默认的order by是不区分大小写的
##建表
create table test_collate
(id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
text varchar(40) NOT NULL
)
##插入数据
insert into test_collate(text) values(‘aaa’),(‘bbb’),(‘AAA’),(‘BBB’);

现在,如果我们按照text排序:

mysql> select * from test_collate order by text;

image.png

结果表明,大写的AAA和小写的aaa被认为是一样的, 都排在BBB和bbb前面


现在,如果我们按照text排序,使用utf8mb4_bin:

现在,如果我们按照text排序,使用utf8mb4_bin:
select * from test_collate order by text collate utf8mb4_bin;

image.png

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
16天前
|
消息中间件 关系型数据库 MySQL
MySQL 到 Kafka 实时数据同步实操分享(1),字节面试官职级
MySQL 到 Kafka 实时数据同步实操分享(1),字节面试官职级
|
16天前
|
机器学习/深度学习 关系型数据库 MySQL
MySQL 到 Greenplum 实时数据同步实操分享,2024年最新【Python面试题
MySQL 到 Greenplum 实时数据同步实操分享,2024年最新【Python面试题
|
18天前
|
存储 关系型数据库 MySQL
MySQL第五战:常见面试题(下)
MySQL第五战:常见面试题(下)
|
18天前
|
关系型数据库 MySQL
MySQL第四战:视图以及常见面试题(上)
MySQL第四战:视图以及常见面试题(上)
|
18天前
|
SQL 关系型数据库 MySQL
Python与MySQL数据库交互:面试实战
【4月更文挑战第16天】本文介绍了Python与MySQL交互的面试重点,包括使用`mysql-connector-python`或`pymysql`连接数据库、执行SQL查询、异常处理、防止SQL注入、事务管理和ORM框架。易错点包括忘记关闭连接、忽视异常处理、硬编码SQL、忽略事务及过度依赖低效查询。通过理解这些问题和提供策略,可提升面试表现。
42 6
|
18天前
|
存储 Oracle 关系型数据库
【MySQL面试题pro版-12】
【MySQL面试题pro版-12】
15 0
|
18天前
|
存储 关系型数据库 MySQL
【MySQL面试题pro版-11】
【MySQL面试题pro版-11】
20 0
|
18天前
|
SQL 关系型数据库 MySQL
【MySQL面试题pro版-10】
【MySQL面试题pro版-10】
19 1
|
18天前
|
缓存 关系型数据库 MySQL
【MySQL面试题pro版-9】
【MySQL面试题pro版-9】
25 1
|
18天前
|
存储 SQL 关系型数据库
【MySQL面试题pro版-8】
【MySQL面试题pro版-8】
16 0