在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
?creates tables in the?system tablespace. Ifinnodb_file_per_table
?is enabled,?InnoDB
?creates each new table using its own?.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_