[[411180]]
我们今天就开始学习 MySQL 中另外一个非常重要的共独立存储引擎 InnoDB 了。
要说 InnoDB,享表我们就不得不先来说说另外一个比较重要的空间话题表空间和共享表空间,这也是表空我们本文的主题。
对于 InnoDB 存储引擎来说,间用它可以将每张表存放于独立的个好表空间,即 tablename.ibd 文件;也可以将数据存放于 ibdata 的共独立共享表空间,一般命名是享表 ibdataX,后面的空间 X 是一个具体的数字。
我们先来体验看看这两种有什么区别。
首先我们执行如下代码可以查看是否开启了独立表空间:
- show variables like 'innodb_file_per_table';
可以看到,默认情况下,独立表空间是开启的。
这个时候我们来创建一个使用了 InnoDB 引擎的表,如下(默认存储引擎就是 InnoDB):
- create table book(id int,name varchar(255));
创建完成后,我们来到存放数据文件的目录下,可以看到如下文件:
可以看到,当前表被存放在独立的 book.ibd 文件中。
存放于独立表空间的表都将会以独立文件的方式来进行存储,每一个表都有一个 .frm 表描述文件(这个和 MyISAM 引擎一致),还有一个 .ibd 文件,这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。
接下来我们执行如下代码,修改 innodb_file_per_table 的值为 OFF,即关闭独立表空间,如下:
关闭之后,再来创建新表:
- create table book2(id int,name varchar(255));
新表创建成功之后,此时我们再去表目录下查看文件,发现并没有一个名为 book2.ibd 的文件,说明此时的表已经存放于共享表空间了。
那么共享表空间的 ibdata1 文件又在哪里呢?其实就在 MySQL 存放数据库的目录下:
我们可以通过如下命令查看 ibdata1 的默认大小:
- show variables like 'innodb_data_file_path';
可以看到,默认大小是 12M。
需要注意的是,innodb_file_per_table 要在创建表之前修改,创建表之后再去修改,是不会影响已有的表结构的。
要搞明白要用哪一种表空间,我们得先明白两种不同表空间各自的特点。
2.1 独立表空间
优势
缺点
2.2 共享表空间
优势
缺点
经过以上的分析,相信小伙伴们已经明白了,在实际项目中,还是首选独立表空间比较好,事实上,从 MySQL5.6 开始,独立表空间就已经成为默认选项了。
最后还有一个问题,如果一开始创建的是共享表空间,那么还能迁移到独立表空间吗?当然可以!参考如下四个步骤:
好啦,今天就和小伙伴们聊一聊共享表空间和独立表空间,InnoDB 的其他玩法我们后面再继续介绍~
本文转载自微信公众号「江南一点雨」,可以通过以下二维码关注。转载本文请联系江南一点雨公众号。
责任编辑:武晓燕 来源: 江南一点雨 MySQL共享表独立表
(责任编辑:娱乐)
贝达药业(300558.SZ)公布消息:凯铭投资解押239万股及质押的511万股延期购回
马斯克热推AI助手 Grok 为X“Premium+”标配每月16美元
探索Kubernetes的高可用性:单Master集群和多Master节点集群方案
分析师:苹果最早将于明年底将生成式AI整合到iPhone和iPad中
网评《马斯克传》是“爽文结构 循环剧情” 微博CEO:+1 -
央行上海总部:10月人民币存款增加3311亿元 住户存款减少72亿元
别克世纪 CENTURY 郭培联名高定系列车型发布:全球限量 5 台,108.99 万元