MySQL8.0 新特性随笔

1、概述

本文主要随笔记录一些MySQL8.0相较于5.7版本,有哪些不同之处。

2、索引

2.1、索引跳跃扫描

有这样一个复合索引: index_a_b_c(a, b, c);然后执行如下sql:

sql 复制代码
select * from T where b = '1' and c = '3'

5.7中不会走这个复合索引。

8.0中如果a字段仅有几个不同值的情况下走这个复合索引。

因此在8.0中可以把区分度高的字段建立在复合索引的最前面,比如性别。

2.2、降序索引

8.0新增降序索引:

sql 复制代码
index_c1_c2(c1, c2 desc);
sql 复制代码
# 会走索引排序
order by c1,c2 desc;
order by c1 desc,c2;

# 不会走索引排序
order by c1, c2;

2.3、group by 隐式排序

sql 复制代码
group by a1

5.7会在分组的时候做隐式排序,即先排序再分组。

8.0则不会做隐式排序了。(要排序就需要指定加 order by)

2.4、隐藏索引

8.0新增可以把指定索引设置成隐藏索引的功能,类似于索引软删,一般是用于测试索引被删了的情况下会不会影响业务,如果确实不影响,这时就可以真正的把索引物理删除掉。

设置成隐藏索引的效果:sql查询时不会走这个索引,就算声明force index也不会走这个索引。但是索引物理是存在的。

隐藏索引可以session级临时开启使用。

2.5、函数索引

5.7中对索引字段使用了函数后会导致索引失效。

8.0新增了函数索引的功能,专门用于给函数生效索引的情况:

sql 复制代码
# 给c1字段加一个UPPER()函数的索引,这个函数的作用是转为大写。
idx_upper_c1(UPPER(c1))

2.6、buffer pool大小自适应参数

8.0中新增该参数innodb_dedicated_server默认关闭,设置成开启时,会自己尽量的去扩大内存占用,尽量的使用上机器资源,一般在一台仅部署了MySQL的机器中开启。

2.7、死锁检查

死锁检查参数innodb_deadlock_detect是默认开启的,在生产环境下应该避免死锁,且锁等待时间不应该设置过长。 因此8.0提供了额外的可以关闭该死锁参数的接口。

2.8、undo log不再使用表空间

5.7的undo log其实是存在MySQL的系统表里面的,8.0就单独移出来,存在磁盘文件undo文件中了。

2.9、窗口函数

8.0新增了窗口函数,便于数据可以更好的进行分组、聚合。

关键字partition by over

相比于group by,窗口函数不会合并结果。

2.10、DDL操作原子化

当t4表不存在时,执行一下sql:

sql 复制代码
drop table t1, t4;

5.7中t1删除成功,t4删除失败。

8.0中t1、t4都删除失败。

相关推荐
·云扬·1 天前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克31 天前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql
luoluoal1 天前
基于深度学习的web端多格式纠错系统(源码+文档)
python·mysql·django·毕业设计·源码
eWidget1 天前
随机森林原理:集成学习思想 —— Java 实现多棵决策树投票机制
java·数据库·随机森林·集成学习·金仓数据库
Traced back1 天前
SQL Server 核心语法+进阶知识点大全(小白版)
数据库·sqlserver
资深web全栈开发1 天前
PostgreSQL枚举还是字符串:ENUM vs VARCHAR + CHECK 的权衡
数据库·postgresql
凯子坚持 c1 天前
C++基于微服务脚手架的视频点播系统---客户端(4)
数据库·c++·微服务
OceanBase数据库官方博客1 天前
OceanBase场景解码系列三|OB Cloud 如何稳定支撑中企出海实现数 10 倍的高速增长?
数据库·oceanbase·分布式数据库
m0_561359671 天前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
山岚的运维笔记1 天前
SQL Server笔记 -- 第14章:CASE语句
数据库·笔记·sql·microsoft·sqlserver