Mysql InnoDB 共享表空间和独立表空间

  • 时间:
  • 浏览:0
  • 来源:大发5分6合APP下载_大发5分6合APP官方

本文作者:JOHN QQ:1913066696 (请备注数据库)

********************************************************************************************************************

5.3共享表空间转化为独立表空间的方法(参数innodb_file_per_table=1需用设置)

单个表的转换操作,脚本:alter table table_name engine=innodb;

4.1 独立表空间的优点

脚本:show variables like "innodb_file_per_table";

单表增加过大,当单表占用空间过大时,存储空间匮乏,也能从操作系统层面思考处里方法;

二、查看数据库的表空间

3.1 共享表空间的优点

pathtodatafile:sizespecification;pathtodatafile:sizespec;.;pathtodatafile:sizespec[:autoextend[:max:sizespecification]]

ORACLE技术博客:

ORACLE 猎人笔记 http://blog.itpub.net/1267930/

独立表空间:

innodb_file_per_table=0 为使用共享表空间

l 表空间有1个文件组成:ibdata1、ibdata2、ibdata3、ibdata4,每个文件的大小为10M,当每个文件都满了的完后 ,ibdata4会自动扩展;

4.2 独立表空间的缺点

所有的数据和索引存塞进一有1个文件,着实也能把一有1个大文件分成多个小文件,假若多个表及索引在表空间中混合存储,当数据量非常大的完后 ,表做了几瓶删除操作后表空间中不可能 有几瓶的空隙,特别是对于统计分析,对于老要删除操作的类式应用最不适合用共享表空间。

对于使innodb-plugin的Innodb使用turncate table也会使空间收缩。

当有几瓶的表需用操作的完后 ,先把数据库导出,假若删除数据再进行导入操作,该操作也能用mysqldump进行操作(http://blog.itpub.net/1267930/viewspace-1259451/)

共享表空间分配后也能回缩:当老要老要出现临时建索引或是创建一有1个临时表的操作表空间扩大后,假若删除相关的表也没方法回缩那部分空间了(也能理解为oracle的表空间10G,假若才使用10M,假若操作系统显示mysql的表空间为10G),进行数据库的冷备更慢;

mysql> show variables like "innodb_file_per_table";

既然Innodb有共享表空间和独立表空间并算是类型,那么 这并算是表空间发生肯定都是完后 此人 的应用的场景,发生即合理。以下是摘自mysql官方的好多好多 介绍:

不可能 用 autoextend 选项描述最后一有1个数据文件,当 InnoDB 用尽所有表自由空间后不可能 自动扩充最后一有1个数据文件,每次增量为 8 MB。示例:

******************************************************************************************************

四、独立表空间的优缺点

修改innodb_file_per_table的参数值即可,假若修改也能影响完后 不可能 使用过的共享表空间和独立表空间;

一、概念

数据和文件塞进一齐方便管理。

5.2 修改数据库的表空间管理方法

5.1 查看当前数据库的表空间管理类型

每个表都是自已独立的表空间,每个表的数据和索引都会发生自已的表空间中,也能实现单表在不同的数据库中移动。

3.2 共享表空间的缺点

innodb_file_per_table=1 为使用独占表空间

l 当前的存储空间满的完后 ,也能在好多好多 的磁盘打上去数据文件,语法如下:语法如下所示:

前言:学习mysql的完后 老要习惯性的和oracle数据库进行比较。在学习mysql InnoDB的存储结构的完后 也免不了跟oracle进行比较。Oracle的数据存储有表空间、段、区、块、数据文件;mysql InnoDB的存储管理也类式,假若mysql增加了一有1个共享表空间和独立表空间的概念;

共享表空间: Innodb的所有数据保发生一有1个单独的表空间后边,而这个 表空间也能由好多好多 个文件组成,一有1个表也能跨多个文件发生,好多好多 其大小限制不再是文件大小的限制,假若其自身的限制。从Innodb的官方文档中也能看到,其表空间的最大限制为64TB,也假若说,Innodb的单表限制基本上也在64TB左右了,当然这个 大小是包括这个 表的所有索引等好多好多 相关数据。

ON代表独立表空间管理,OFF代表共享表空间管理;(查看单表的表空间管理方法,需用查看每个表是算是有单独的数据文件)

对于使用独立表空间的表,不管为什么删除,表空间的碎片无需太严重的影响性能,假若还有不可能 处里。

五、共享表空间和独立表空间之间的转换

三、共享表空间优缺点

不管是共享表空间和独立表空间,都会发生innodb_data_file文件,不可能 这个 文件不仅仅要存放数据,假若需用充当着类式于ORACLE的UNDO表空间等好多好多 角色。

mysql> show variables like 'innodb_data%';

Drop table操作自动回收表空间,不可能 对于统计分析或是日值表,删除几瓶数据也可不可不还可不可以通过:alter table TableName engine=innodb;回缩无需的空间。

总结:经过以上操作便完成数据库的存储空间的转换,了解技术是为了更好的利用技术,当数据量很小的完后 建议使用共享表空间的管理方法。数据量很大的完后 建议使用独立表空间的管理方法。

空间也能回收(除drop table操作处,表空也能自已回收)

表空间也能分成多个文件存塞进各个磁盘,好多好多 表也就也能分成多个文件存塞进磁盘上,表的大小不受磁盘大小的限制(好多好多 文档描述特别问题报告 报告 )。