广告
返回顶部
首页 > 资讯 > 数据库 >MySQL DDL操作实践是怎样的
  • 798
分享到

MySQL DDL操作实践是怎样的

2024-04-02 19:04:59 798人浏览 泡泡鱼
摘要

本篇文章给大家分享的是有关Mysql DDL操作实践是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。根据网上的DDL 树状图,自己cop

本篇文章给大家分享的是有关Mysql DDL操作实践是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

根据网上的DDL 树状图,自己copy了一份:/file/imgs/upload/202210/18/mppgv25foue.jpg?_=1547952296662

对不同版本的add index的处理方式,这篇文章写得不错:https://www.jb51.net/article/75217.htm

--
相关实践

表结构:

CREATE TABLE `tt` (
`id` int(11) DEFAULT NULL,
`age` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
row in set (0.01 sec)

行数:

data_migration@192.168.7.21:3306 test>select count(*) from tt;
+----------+
| count(*) |
+----------+
| 12582912 |
+----------+

data_migration@192.168.7.21:3306 test>alter table tt add index idx_id(id);
Query OK, 0 rows affected (27.49 sec)
Records: 0  Duplicates: 0  Warnings: 0

增加id索引
临时表:只增加了#sql-1e65_68.frm,未增加idb
数据量变化:448M -> 676M

data_migration@192.168.7.21:3306 test>alter table tt add name1 varchar(12);
Query OK, 0 rows affected (44.72 sec)
Records: 0  Duplicates: 0  Warnings: 0

新增字段
临时表:增加#sql-1e65_68.frm, #sql-ib231-4246726206.ibd,完成时增加#sql-ib255-4246726207.ibd没有tt.ibd,最后生成tt.idb
数据量变化:临时表一直增加到和新表同样的数据量后,最后完成新表替换,新表 676M->740M

-rw-r-----  1 mysql mysql 740M 1月   8 11:30 #sql-ib231-4246726206.ibd
-rw-r-----  1 mysql mysql 8.4K 1月   8 11:06 tt.frm
-rw-r-----  1 mysql mysql 676M 1月   8 11:08 tt.ibd
[root@dbtest-21 test]# ll -ah
-rw-r-----  1 mysql mysql 8.5K 1月   8 11:30 #sql-1e65_68.frm
-rw-r-----  1 mysql mysql 740M 1月   8 11:30 #sql-ib231-4246726206.ibd
-rw-r-----  1 mysql mysql 8.4K 1月   8 11:06 tt.frm
-rw-r-----  1 mysql mysql 676M 1月   8 11:08 tt.ibd
[root@dbtest-21 test]# ll -ah
-rw-r-----  1 mysql mysql 8.5K 1月   8 11:30 #sql-1e65_68.frm
-rw-r-----  1 mysql mysql 740M 1月   8 11:30 #sql-ib231-4246726206.ibd
-rw-r-----  1 mysql mysql 676M 1月   8 11:08 #sql-ib255-4246726207.ibd
-rw-r-----  1 mysql mysql 8.4K 1月   8 11:06 tt.frm
[root@dbtest-21 test]# ll -ah
-rw-r-----  1 mysql mysql 8.5K 1月   8 11:30 tt.frm
-rw-r-----  1 mysql mysql 740M 1月   8 11:30 tt.ibd

data_migration@192.168.7.21:3306 test>alter table tt modify age varchar(20);
Query OK, 12582912 rows affected (2 min 36.80 sec)
Records: 12582912  Duplicates: 0  Warnings: 0

修改字段
临时表:增加#sql-1e65_68.frm, #sql-ib231-4246726206.ibd,完成时增加#sql-ib255-4246726207.ibd没有tt.ibd,最后生成tt.idb
数据量变化:临时表一直增加到和新表同样的数据量后,最后完成新表替换
时间增加
TIPS:
1.新增空字段,磁盘会额外占用新加字段的空间。
2.修改增加的新的空字段类型,可以瞬间完成。

--

alGorithm = copy/inplace    
copy会一直创建临时表,inplace在不同场景(rebuild、no-rebuild)下都会创建、不创建临时表
copy :copy to tmp table,期间不允许DML
inplace :altering table  允许并发DML,使用了参数innodb_online_alter_log_max_size缓存新的写

以上就是MySQL DDL操作实践是怎样的,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL DDL操作实践是怎样的

本文链接: https://www.lsjlt.com/news/61298.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL DDL操作实践是怎样的
    本篇文章给大家分享的是有关MySQL DDL操作实践是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。根据网上的DDL 树状图,自己cop...
    99+
    2022-10-18
  • PHP+MYSQL的分页是怎样操作的
    本篇文章为大家展示了PHP+MYSQL的分页是怎样操作的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。寫php是簡單的事,但是分頁可困擾小弟好一陣子°因為手邊的書好...
    99+
    2022-10-18
  • MySQL高可用架构的PXC实践是怎样的
    这篇文章给大家介绍MySQL高可用架构的PXC实践是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、PXC简介    官方介绍: &nb...
    99+
    2022-10-18
  • mysql类似merge的操作是怎么样的
    今天就跟大家聊聊有关mysql类似merge的操作是怎么样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。mysql> truncate `2...
    99+
    2022-10-19
  • 关于mysql的相关操作是怎样的
    这篇文章将为大家详细讲解有关关于mysql的相关操作是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、Mysql用户密码修改mysql密码修改有多种...
    99+
    2022-10-18
  • Mysql中关于表的操作是怎样的
    Mysql中关于表的操作是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。创建数据库  createdatabase数据库...
    99+
    2022-10-19
  • MySQL参数调优的最佳实践是怎么样的
    这期内容当中小编将会给大家带来有关MySQL参数调优的最佳实践是怎么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 前言很多时候,RDS用...
    99+
    2022-10-18
  • 数据库MySQL的简单操作是怎样的
    数据库MySQL的简单操作是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。以MySQL为例。一、下载,安装,mysql和navica...
    99+
    2022-10-18
  • MySQL数据库优化的方案与实践是怎样的
    这篇文章给大家介绍MySQL数据库优化的方案与实践是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。最近一段时间,我们整理了一些关于Percona,Linux,Flashcache...
    99+
    2022-10-19
  • TalkingData的Spark On Kubernetes实践是怎样的
    这篇文章给大家介绍TalkingData的Spark On Kubernetes实践是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。众所周知,Spark是一个快速、通用的大规模数据处理平台,和Hadoop的Map...
    99+
    2023-06-19
  • Pythonexe的实际操作步骤是怎样的
    Pythonexe的实际操作步骤是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Python6. 把c:\python25\dlls目录中的.pyd和.dll文件,复制到...
    99+
    2023-06-17
  • MySQL WHERE语句筛选操作符是怎样的
    本篇文章给大家分享的是有关MySQL WHERE语句筛选操作符是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 使用S...
    99+
    2022-10-18
  • Mysql在LONGTEXT字段上作like操作的消耗是怎样的
    这篇文章将为大家详细讲解有关Mysql在LONGTEXT字段上作like操作的消耗是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。# Mysql 51...
    99+
    2022-10-19
  • MySQL中怎样实现分页查询操作
    MySQL中怎样实现分页查询操作,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。MySQL分页查询   &n...
    99+
    2022-10-18
  • MYSQL修改后新版本的操作类是怎样的
    MYSQL修改后新版本的操作类是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 MYSQL...
    99+
    2022-10-19
  • awk的操作是怎么样的
    本篇文章给大家分享的是有关awk的操作是怎么样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。awk是一种用于处理文本、模式匹配的编程语言。与sed和grep,俗称Linux下...
    99+
    2023-06-05
  • Shell 脚本编程的实践是怎样的
    这篇文章跟大家分析一下“Shell 脚本编程的实践是怎样的”。内容详细易懂,对“Shell 脚本编程的实践是怎样的”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入学习“Shell 脚本编...
    99+
    2023-06-28
  • Java Socket通讯的实操作是怎么样的
    今天就跟大家聊聊有关Java Socket通讯的实操作是怎么样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java Socket通讯在我们实际使用的时候有很多我们需要注意的。那么...
    99+
    2023-06-17
  • MySQL中的联结查询和集合操作是怎样的
    这篇文章给大家介绍MySQL中的联结查询和集合操作是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。联结查询联结查询就是指两张或者以上的表之间进行匹配查询,一般称之为水平操作,就是...
    99+
    2022-10-18
  • Oracle Spatial基本操作是怎样的
    Oracle Spatial基本操作是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Spatial主要通过元数据表、空间数据字段(即sd...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作