MySQL 8.0 新特性之原子 DDL

MySQL 8.0 新特性之原子 DDL

MySQL 8.0 新增原子 DDL(Atomic DDL)特性,支持针对库和表相关的 DDL 操作,但前提对象必须是 InnoDB 存储引擎,同时也支持部分非表相关的 DDL 语句,如 CREATE|ALTER|DROP USER,GRANT,REVOKE 等。

新增 innodb_print_ddl_logs 参数,用于控制是否将 DDL 操作日志打印到数据库日志中,默认为 OFF

测试用例1:原子 DDL

MySQL 5.7

复制代码
mysql> show tables;
+--------------------+
| Tables_in_sbtest57 |
+--------------------+
| t1                 |
| t2                 |
+--------------------+
3 rows in set (0.00 sec)

## 执行删除表操作,此时命令报错,因为表 t3 并不存在
mysql> drop table t2,t3;
ERROR 1051 (42S02): Unknown table 'sbtest57.t3'

## 上条 DDL 语句虽执行报错,但 t2 仍然被删除
mysql> show tables;
+--------------------+
| Tables_in_sbtest57 |
+--------------------+
| t1                 |
+--------------------+
2 rows in set (0.00 sec)

MySQL 8.0

复制代码
mysql> show tables;
+-------------------+
| Tables_in_sbtest8 |
+-------------------+
| t1                |
| t2                |
+-------------------+
4 rows in set (0.00 sec)

## 执行删除表操作,此时同样报错
mysql> drop table t2,t3;
ERROR 1051 (42S02): Unknown table 'sbtest8.t3'

## 查看表,t2 未被删除,符合原子 DDL 特性
mysql> show tables;
+-------------------+
| Tables_in_sbtest8 |
+-------------------+
| t1                |
| t2                |
+-------------------+
4 rows in set (0.00 sec)

测试用例2:innodb_print_ddl_logs 参数

复制代码
## MySQL 8.0
## log_error_verbosity,用于控制错误日志中事件的详细程度,默认为 2,设置为 3 可打印更为详细的信息
mysql> set global log_error_verbosity=3;
mysql> set global innodb_print_ddl_logs=1;
mysql> drop table t1;
Query OK, 0 rows affected (0.01 sec)

## MySQL 错误日志
2024-03-06T14:09:47.311610+08:00 31 [Note] [MY-012475] [InnoDB] DDL log insert : [DDL record: DROP, id=68, thread_id=31, table_id=1077]
2024-03-06T14:09:47.311829+08:00 31 [Note] [MY-012473] [InnoDB] DDL log insert : [DDL record: DELETE SPACE, id=69, thread_id=31, space_id=15, old_file_path=./sbtest8/t1.ibd]
2024-03-06T14:09:47.316996+08:00 31 [Note] [MY-012485] [InnoDB] DDL log post ddl : begin for thread id : 31
2024-03-06T14:09:47.317073+08:00 31 [Note] [MY-012479] [InnoDB] DDL log replay : [DDL record: DELETE SPACE, id=69, thread_id=31, space_id=15, old_file_path=./sbtest8/t1.ibd]
2024-03-06T14:09:47.318231+08:00 31 [Note] [MY-012479] [InnoDB] DDL log replay : [DDL record: DROP, id=68, thread_id=31, table_id=1077]
2024-03-06T14:09:47.319411+08:00 31 [Note] [MY-012486] [InnoDB] DDL log post ddl : end for thread id : 31

注:更多关于原子 DDL 的信息,请查看 《MySQL 8.0 Reference Manual:15.1.1 Atomic Data Definition Statement Support》。

相关推荐
刺客-Andy1 小时前
Python 第二十节 正则表达式使用详解及注意事项
python·mysql·正则表达式
哈__1 小时前
MongoDB 平替新方案:金仓多模数据库驱动电子证照国产化落地
数据库·1024程序员节
微学AI2 小时前
国产数据库替代MongoDB的技术实践过程:金仓多模数据库在电子证照系统中的深度应用
数据库·人工智能·1024程序员节
TDengine (老段)2 小时前
TDengine 数据函数 ROUND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·1024程序员节
TDengine (老段)2 小时前
TDengine 数学函数 RAND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
野犬寒鸦2 小时前
从零起步学习MySQL || 第十章:深入了解B+树及B+树的性能优势(结合底层数据结构与数据库设计深度解析)
java·数据库·后端·mysql·1024程序员节
GZ_TOGOGO3 小时前
Oracle OCP考试报名常见问题详解
数据库·oracle·ocp认证
睡不醒的猪儿3 小时前
nginx日志同步阿里云datahub后写入数据库
数据库·nginx·阿里云
xie_zhr3 小时前
【PB案例学习笔记】-46在数据窗口中编辑数据
数据库·his·1024程序员节·干货分享·pb·powerbuilder
小小的木头人3 小时前
Redis 集群安装指南
数据库·redis