文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL 中的共享表空间与独立表空间,用哪个好呢?

2024-12-03 01:28

关注

我们今天就开始学习 MySQL 中另外一个非常重要的存储引擎 InnoDB 了。

要说 InnoDB,我们就不得不先来说说另外一个比较重要的话题表空间和共享表空间,这也是我们本文的主题。

1.独立表空间与共享表空间

对于 InnoDB 存储引擎来说,它可以将每张表存放于独立的表空间,即 tablename.ibd 文件;也可以将数据存放于 ibdata 的共享表空间,一般命名是 ibdataX,后面的 X 是一个具体的数字。

我们先来体验看看这两种有什么区别。

首先我们执行如下代码可以查看是否开启了独立表空间:

  1. show variables like 'innodb_file_per_table'

可以看到,默认情况下,独立表空间是开启的。

这个时候我们来创建一个使用了 InnoDB 引擎的表,如下(默认存储引擎就是 InnoDB):

  1. create table book(id int,name varchar(255)); 

创建完成后,我们来到存放数据文件的目录下,可以看到如下文件:

可以看到,当前表被存放在独立的 book.ibd 文件中。

存放于独立表空间的表都将会以独立文件的方式来进行存储,每一个表都有一个 .frm 表描述文件(这个和 MyISAM 引擎一致),还有一个 .ibd 文件,这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。

接下来我们执行如下代码,修改 innodb_file_per_table 的值为 OFF,即关闭独立表空间,如下:

关闭之后,再来创建新表:

  1. create table book2(id int,name varchar(255)); 

新表创建成功之后,此时我们再去表目录下查看文件,发现并没有一个名为 book2.ibd 的文件,说明此时的表已经存放于共享表空间了。

那么共享表空间的 ibdata1 文件又在哪里呢?其实就在 MySQL 存放数据库的目录下:

我们可以通过如下命令查看 ibdata1 的默认大小:

  1. show variables like 'innodb_data_file_path'

可以看到,默认大小是 12M。

需要注意的是,innodb_file_per_table 要在创建表之前修改,创建表之后再去修改,是不会影响已有的表结构的。

2.该用哪一个?

要搞明白要用哪一种表空间,我们得先明白两种不同表空间各自的特点。

2.1 独立表空间

优势

缺点

2.2 共享表空间

优势

缺点

经过以上的分析,相信小伙伴们已经明白了,在实际项目中,还是首选独立表空间比较好,事实上,从 MySQL5.6 开始,独立表空间就已经成为默认选项了。

3.迁移

最后还有一个问题,如果一开始创建的是共享表空间,那么还能迁移到独立表空间吗?当然可以!参考如下四个步骤:

好啦,今天就和小伙伴们聊一聊共享表空间和独立表空间,InnoDB 的其他玩法我们后面再继续介绍~

本文转载自微信公众号「江南一点雨」,可以通过以下二维码关注。转载本文请联系江南一点雨公众号。

 

来源:江南一点雨内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯