当前位置: 首页 > article >正文

【重学 MySQL】四十九、阿里 MySQL 命名规范及 MySQL8 DDL 的原子化

【重学 MySQL】四十九、阿里 MySQL 命名规范及 MySQL8 DDL 的原子化

  • 阿里 MySQL 命名规范
  • MySQL8 DDL的原子化

在这里插入图片描述

阿里 MySQL 命名规范

  • 强制】表名、字段名必须使用小写字母或数字,禁止出现数字开头,禁止两个下划线中间只出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。
    • 正例:aliyun_admin,rdc_config,level3_name
    • 反例:AliyunAdmin,rdcConfig,level_3_name
  • 强制】禁用保留字,如 desc、range、match、delayed 等,请参考 MySQL 官方保留字。
  • 强制】表必备三字段:id, gmt_create, gmt_modified。
    • 说明:其中 id 必为主键,类型为BIGINT UNSIGNED、单表时自增、步长为 1。gmt_create, gmt_modified 的类型均为 DATETIME 类型,前者现在时表示主动式创建,后者过去分词表示被动式更新
  • 推荐】表的命名最好是遵循 “业务名称_表的作用”。
    • 正例:alipay_task 、 force_project、 trade_config
  • 推荐】库名与应用名称尽量一致。
  • 【参考】合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检索速度。
对象年龄区间类型字节表示范围
150岁之内tinyint unsigned1无符号值:0到255
数百岁smallint unsigned2无符号值:0到65535
恐龙化石数千万年int unsigned4无符号值:0到约43亿
太阳约50亿年bigint unsigned8无符号值:0到约10的19次方

MySQL8 DDL的原子化

MySQL 8.0引入了DDL(数据定义语言)的原子性特性,通过统一数据字典DD和DDL_LOG机制来确保DDL操作的原子性。

  1. 原子DDL的定义:原子DDL语句将数据字典更新、存储引擎操作和与DDL操作相关联的二进制日志写入组合成单个原子操作。这意味着,即使服务器在操作过程中停止运行,操作也可以提交,将适用的更改保存到数据字典、存储引擎和二进制日志中,或者回滚。

  2. 数据字典的统一:在MySQL 8.0之前,元数据存储在元数据文件、非事务表和存储引擎特定的字典中,这需要中间提交。MySQL 8.0引入了统一的数据字典DD,并废弃了server层的元数据(如.frm、.opt、.par、.trg等),将InnoDB的元数据抽象出一条DD接口供server层和InnoDB层共用。这消除了中间提交的障碍,使得将DDL语句操作重构为原子操作成为可能。

  3. DDL_LOG机制:为了确保DDL操作的原子性,MySQL 8.0还引入了一套DDL_LOG机制。在执行DDL的过程中,会记录DDL操作到DDL_LOG表中。DDL_LOG表是InnoDB引擎表,通过保证DDL_LOG数据与DD数据字典修改达成一致,来解决DD数据字典修改、引擎层修改和写binlog一致性问题。在DDL事务提交后,会读取DDL_LOG内容并进行回放执行,以完成DDL操作的收尾动作。

  4. 原子DDL的特性

    • 原子DDL支持表DDL语句和非表DDL语句。与表相关的DDL操作需要存储引擎支持,目前只有InnoDB存储引擎支持原子DDL。
    • DDL语句,无论是原子的还是其他的,都会隐式地结束当前会话中任何活动的事务。这意味着DDL语句不能在另一个事务中执行,不能在事务控制语句(如START TRANSACTION)中执行,或者与同一事务中的其他语句结合使用。
    • 原子化的DDL操作在执行过程中,如果MySQL服务突然停止,不会像之前的版本那样生成一个报错文件,而是会回滚操作。

综上所述,遵循阿里MySQL命名规范可以提高数据库的可读性和可维护性,而MySQL8 DDL的原子化特性则确保了DDL操作的一致性和可靠性。


http://www.kler.cn/news/329569.html

相关文章:

  • elasticsearch 写入新数据测试(二)
  • 练习题 - DRF 3.x Validators 验证使用示例和配置方法
  • Java中的switch分支结构
  • 解析Vue2源码diff算法更新子节点逻辑以及优化
  • 专访 Bitlayer 联合创始人 Charlie:探索比特币 Layer2 技术的未来
  • 【高阶数据结构】平衡二叉树(AVL)的删除和调整
  • Hadoop三大组件之MapReduce(一)
  • 计算机毕业设计 C语言学习辅导网站的设计与实现 Java实战项目 附源码+文档+视频讲解
  • C#秒如何转为时分秒格式
  • 智能BI项目第六期
  • 亚信安全天穹5分钟勒索体检 免费试用今起上线
  • RabbitMQ高级特性-持久性
  • STM32单片机编程调试常见问题(二) Keil5软件调试中常见的配置问题
  • 【GEE学习第一期】GEE介绍、注册及基本使用
  • Leetcode 3301. Maximize the Total Height of Unique Towers
  • Spring Boot技术栈:打造高效在线商城
  • 【经典机器学习算法】谱聚类算法及其实现(python)
  • 【DirectX sdk 学习使用】
  • DRF笔记
  • Qt --- 常用控件的介绍---Widget属性介绍
  • 如何隐藏Windows10「安全删除硬件」里的USB无线网卡
  • 计算机毕业设计 智能旅游推荐平台的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 【MySQL 06】表的增删查改
  • Word样式的同步与重置
  • Golang | Leetcode Golang题解之第437题路径总和III
  • LeetCode从入门到超凡(四)深入浅出理解贪心算法
  • 使用Electron将vue项目改桌面程序
  • SpringBoot学习笔记(2)
  • 服务器感染了.baxia勒索病毒,如何确保数据文件完整恢复?
  • 通信工程学习:什么是POP3邮局协议版本3