news 2026/4/16 14:01:43

MySQL 精度扩展时候的DDL阻塞对比Oracle

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 精度扩展时候的DDL阻塞对比Oracle

曾经我分析过在MySQL数据库上字段扩位是否只是快速更新元数据的

  • 那次是因为是在实际工作中意外遇到的问题,所以做了实验
  • 得出在64以下改变没有问题。64以上的改变也没有问题。但是当从小于64的改到64以上时候则会发生问题。(不是简单的改元数据)
  • 当时这个结论使得我们在日常变更中可以判断影响面。

最近有一个新的场景,精度变更

  • 出于对上次的判断,我觉得这里有一些不确定性。十有八九会有要注意的问题。
  • 事实证明我判断正确的

实际效果

  • 模拟一个100M以上的表
mysql> select count(*) from test_data; +----------+ | count(*) | +----------+ | 1000000 | +----------+ 1 row in set (0.74 sec) mysql> desc test_data; +-------+---------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+---------------+------+-----+---------+----------------+ | id | int | NO | PRI | NULL | auto_increment | | m | varchar(30) | YES | | NULL | | | n | varchar(80) | YES | | NULL | | | x | decimal(12,6) | YES | | NULL | | | y | decimal(18,3) | YES | | NULL | | +-------+---------------+------+-----+---------+----------------+ 5 rows in set (0.05 sec) mysql> alter table test_data add z decimal(10,3); Query OK, 0 rows affected (0.13 sec) Records: 0 Duplicates: 0 Warnings: 0 - 可见增加字段是直接元数据变更。 mysql> mysql> alter table test_data modify m varchar(50); Query OK, 0 rows affected (0.02 sec) Records: 0 Duplicates: 0 Warnings: 0 - 可见上次结论,64以下到64以上会耗时较长,数据不仅仅是元数据变更 mysql> alter table test_data modify m varchar(150); Query OK, 1000000 rows affected (49.92 sec) Records: 1000000 Duplicates: 0 Warnings: 0 mysql> alter table test_data modify m varchar(160); Query OK, 0 rows affected (0.02 sec) Records: 0 Duplicates: 0 Warnings: 0 - 而64以上再次改变是,仅仅元数据变更。 - 那么数据精度改变。从实际效果而言,耗时较长。数据重新在做组织。 - mysql> alter table test_data modify x decimal(18,6); Query OK, 1000000 rows affected (47.20 sec) Records: 1000000 Duplicates: 0 Warnings: 0 mysql> alter table test_data modify y decimal(18,6); Query OK, 1000000 rows affected (46.73 sec) Records: 1000000 Duplicates: 0 Warnings: 0

结论很明显了。那么我就想在Oracle下如何表现?

XXG@xxg> desc test_data; 名称 是否为空? 类型 ----------------------------------------------------------------- -------- -------------------------------------------- M VARCHAR2(30) N VARCHAR2(80) X NUMBER(12,6) Y NUMBER(18,3) XXG@xxg> set timing on; XXG@xxg> select count(*) from test_data; COUNT(*) ---------- 2500000 已用时间: 00: 00: 00.38 XXG@xxg> alter table test_data add z decimal(10,3); 表已更改。 - 在11g(2005年)就实现的增加字段是直接元数据变更,是所有数据库都学习和借鉴的。 已用时间: 00: 00: 01.23 XXG@xxg> alter table test_data modify m varchar(50); 表已更改。 已用时间: 00: 00: 00.19 XXG@xxg> alter table test_data modify m varchar(150); 表已更改。 已用时间: 00: 00: 00.16 XXG@xxg> alter table test_data modify m varchar(160); 表已更改。 - 无论如何扩位,都是快速完成。不存在数据重组的问题。 已用时间: 00: 00: 00.15 XXG@xxg> alter table test_data modify x decimal(18,6); 表已更改。 已用时间: 00: 00: 00.16 XXG@xxg> alter table test_data modify y decimal(18,6); alter table test_data modify y decimal(18,6) * 第 1 行出现错误: ORA-01440: 要减小精度或标度, 则要修改的列必须为空 已用时间: 00: 00: 00.39 XXG@xxg> alter table test_data modify y decimal(21,6); 表已更改。 已用时间: 00: 00: 00.05
  • 从最后的结果来说,只要精度扩大给到对应的范围,也是毫秒完成变更,不存在耗时长的问题。

这些后续可以更好的判断DDL时候的阻塞情况

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 17:13:00

【开题答辩全过程】以 基于JavaEE的超市自助结算平台的开发为例,包含答辩的问题和答案

个人简介 一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等 开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。 感谢大家…

作者头像 李华
网站建设 2026/4/16 12:28:06

网络交换机原理与实践:从二层交换到高级特性的全面解析

前言 在现代计算机网络中,交换机是构建局域网的核心设备。相比于老旧的集线器采用广播模式转发所有数据,交换机通过学习MAC地址、构建交换表、进行智能转发等机制,大幅提升了网络效率和安全性。然而,许多网络管理员和学生对交换机…

作者头像 李华
网站建设 2026/4/16 15:53:35

从入门到精通:Postman和Eolinker的接口测试全攻略

http状态码 每发出一个http请求之后,都会有一个响应,http本身会有一个状态码,来标示这个请求是否成功,常见的状态码有以下几种: 200 2开头的都表示这个请求发送成功,最常见的就是200,就代表这…

作者头像 李华
网站建设 2026/4/16 12:28:59

AI诗歌:老街的弦理论的地质振动

11、《老街的弦理论的地质振动》 钟声从巷口传来 “叮——” 像地壳的震动 孩子们用纸船载着钟声 漂过积水的街面 “我们是地球的音符”他们说, 纸船撞上未拆的信封 第四幕:《暗语之河》 1、《镜中密语》 镜面浮起一串数字 “01001001” 是“我”在…

作者头像 李华
网站建设 2026/4/16 14:03:05

【计算机视觉、关键点检测、特征提取和匹配】基于SIFT、PCA-SIFT和GLOH算法在不同图像之间建立特征对应关系,并实现点匹配算法和图像匹配附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…

作者头像 李华