mysql中查看表结构的指令(mysql表空间的概念)

 2025-05-01  阅读 603  评论 0

摘要:在mysql中,也出现了类似oracle中的表空间概念,今天小编就来说说关于mysql中查看表结构的指令?下面更多详细答案一起来看看吧!mysql中查看表结构的指令在mysql中,也出现了类似oracle中的表空间概念。mysql表空间是什么意思呢?当我们使用Innodb数据库引擎,开启了Innod

mysql中,也出现了类似oracle中的表空间概念,今天小编就来说说关于mysql中查看表结构的指令?下面更多详细答案一起来看看吧!

mysql中查看表结构的指令(mysql表空间的概念)

mysql中查看表结构的指令

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

mysql表空间是什么意思呢?

当我们使用Innodb数据库引擎,开启了Innodb的innodb_file_per_table这个参数之后(innodb_file_per_table = 1),也就是启用InnoDB的独立表空间模式。此时,在innodb数据库下,新建表,就会在对应的数据库目录下会多出来一个.ibd这个文件。这个就是表对应的数据文件了。mysql会把这个innodb表的数据存放在这个文件中。并且每个innodb表此时都会对应这么一个ibd文件。而不像以前,所有的表都放在一个数据文件中。

那么这样做有什么好处呢?

可以实现单表在不同的数据库之间移动。具体怎么移动呢?假设有两个数据库,一个test,一个tt。

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

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

需要说明的是:

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

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

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

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

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

,

版权声明:xxxxxxxxx;

原文链接:http://cn.tdroid.net/cef2cCz0HAAkGVlE.html

发表评论:

管理员

  • 内容265050
  • 积分0
  • 金币0
关于我们
lecms主程序为免费提供使用,使用者不得将本系统应用于任何形式的非法用途,由此产生的一切法律风险,需由使用者自行承担,与本站和开发者无关。一旦使用lecms,表示您即承认您已阅读、理解并同意受此条款的约束,并遵守所有相应法律和法规。
联系方式
电话:
地址:广东省中山市
Email:
注册登录
注册帐号
登录帐号

Copyright © 2022 太卓开发网 Inc. 保留所有权利。 泰达科技网易库网

页面耗时0.1041秒, 内存占用1.33 MB, 访问数据库18次