首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

MySQL INNODB表空间两种配置阐释

2013-10-28 
MySQL INNODB表空间两种配置阐述在mysql中,也出现了类似oracle中的表空间概念。????? 开启了Innodb的innodb

MySQL INNODB表空间两种配置阐述

在mysql中,也出现了类似oracle中的表空间概念。

????? 开启了Innodb的innodb_file_per_table这个参数之后【innodb_file_per_table = 1】,也就是启用InnoDB的独立表空间模式,便于管理。此时,在新建的innodb表的数据库目录下会多出来一个.ibd这个文件。mysql会把这个innodb表的数据存放在这个文件中。并且每个innodb表此时都会对应这么一个ibd文件。

mysql手册说明很清楚:

????? If?innodb_file_per_table?is disabled (the default),?innodb_file_per_table?is enabled,?.ibd?file?for storing data and indexes, rather than in the system tablespace.?

? ? ? 很搞不懂为什么innodb_file_per_table默认是不开启的。 ? ? ?

? ? ? 开启之后有什么好处呢?

????? 可以实现单表在不同的数据库之间移动。

????? InnoDB 默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,这样就感觉很不方便,增删数据库的时候,ibdata1文件不会自动收缩,ibdata1文件增长到几十G都有可能,单个数据库的备份也将成为问题。通常只能将数据使用mysqldump 导出,然后再导入解决这个问题。共享表空间在Insert操作上有优势。其它都没独立表空间表现好。当启用独立表空间时,请合理设置innodb_open_files 的值。

-------------------------------------------------------------------------------

需要说明的是:

1、设置了独立表空间之后,如果改成了共享表空间,那么,此时如果执行表的插入操作,数据会存放在哪里呢?

对于之前已经存在了的表,还是存放在独立表空间。对于新建的表,就会存放在共享表空间了。

2、如果一开始用了共享表空间,后来改了innodb_file_per_table变量的值,改成独立表空间了,那么数据如何存储?

对于已经存在了的innodb引擎的表来说,数据还是存放在共享表空间的,而此时如果创建了新的表,那么就会在数据库的目录中多出一个.ibd的文件用于存储这个新表的数据。

总结上面的1、2,就是:原来的还是按照原来的方式存储。新的表按照新的规则来存储。

3、mysql在第二点上处理的不太妥当,新旧数据为什么要分开存放,为什么不能自动把共享表空间里的数据导入到独立表空间中?

?

热点排行