0

0

mysql数据库中的表空间与数据文件管理

P粉602998670

P粉602998670

发布时间:2026-01-18 08:29:38

|

851人浏览过

|

来源于php中文网

原创

MySQL表空间分system/file-per-table/general三类:system即ibdata1,存系统数据;file-per-table每表独立.ibd;general需手动创建共享表空间。

mysql数据库中的表空间与数据文件管理

MySQL 表空间类型怎么区分:system / file-per-table / general

MySQL 的表空间不是抽象概念,而是对应磁盘上真实的数据文件。关键区别innodb_file_per_table 配置和 CREATE TABLE 时是否显式指定 TABLESPACE

默认开启 innodb_file_per_table=ON(MySQL 5.6.6+),此时每张 InnoDB 表生成独立的 .ibd 文件;若关闭,则所有表数据都写入共享表空间 ibdata1 —— 这会导致 DROP TABLE 后空间无法回收,且无法用 OPTIMIZE TABLE 收缩单表。

  • SYSTEM 表空间:固定为 ibdata1(及可能的 ibdata2 等),存储数据字典、undo log、系统表等,不可删除
  • FILE_PER_TABLE 表空间:每个表一个 .ibd,路径在 datadir/数据库名/表名.ibd,支持 TRUNCATEOPTIMIZE 回收空间
  • GENERAL 表空间:由 CREATE TABLESPACE ... ADD DATAFILE 创建,可跨库共享,但需手动管理路径与权限,且不支持临时表

如何查某张表用的是哪种表空间?

直接查 INFORMATION_SCHEMA.INNODB_SYS_TABLES 最可靠,SPACE 字段值为 0 表示 system 表空间,非 0 则是 file-per-table 或 general 表空间。

SELECT NAME, SPACE, FILE_FORMAT, ROW_FORMAT 
FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES 
WHERE NAME = 'testdb/users';

再结合 INFORMATION_SCHEMA.FILES 查物理路径:

SELECT TABLESPACE_NAME, FILE_NAME, TOTAL_EXTENTS 
FROM INFORMATION_SCHEMA.FILES 
WHERE TABLESPACE_NAME = 'testdb/users' OR TABLESPACE_NAME = 'innodb_system';

注意:FILES 视图只显示已打开的数据文件,冷备后未重启 MySQL 可能看不到新 .ibd

MMM金融互助系统源码
MMM金融互助系统源码

MMM金融互助系统源码是以thinkphp为核心进行开发的3m金融互助平台。程序安装说明:1.恢复数据:将“数据备份”文件夹中的 urkeji.sql 文件请采用phpMyAdmin进行导入; 2.配置Sql数据库信息,文件路径:根目录下 config.php3.后台管理地址:http://域名/admin.php 用户名:100000 密码:admin1

下载

迁移表到 GENERAL 表空间要注意什么?

不是所有场景都适合用 GENERAL 表空间。它主要解决多表共用一个大文件、统一管理 I/O 调度的需求,但会引入额外约束:

  • 目标表空间必须已存在,且 ADD DATAFILE 指定的路径对 mysqld 进程可读写
  • 迁移前表不能有全文索引、虚拟列、外键引用(除非所有关联表也在同一表空间)
  • 执行 ALTER TABLE t1 TABLESPACE = my_ts 会重建整张表,期间锁表(online DDL 在 8.0.12+ 支持部分场景无锁,但表空间迁移仍需 copy algorithm)
  • 迁移后 .ibd 文件被移走,原路径只剩一个空壳,误删会导致表不可访问

ibdata1 越来越大,能 shrink 吗?

不能在线 shrink。因为 ibdata1 是 SYSTEM 表空间,包含 undo logs、数据字典等核心结构,MySQL 不提供收缩接口。常见错误操作是直接清空或删除 ibdata1,这会导致实例启动失败。

真正可行的路径只有两个:

  • 如果启用了 innodb_undo_tablespaces 且 undo 存在独立表空间中,可通过 SET GLOBAL innodb_undo_log_truncate=ON 配合 innodb_max_undo_log_size 自动截断旧 undo
  • 彻底重建:导出所有数据(mysqldump --all-databases),停库,删除 ibdata1 + ib_logfile*,重启初始化新实例,再导入 —— 这是唯一能让 ibdata1 回到初始大小的方式

所以一开始就把 innodb_file_per_table=ON 设为强制策略,比后期补救重要得多。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

663

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 797人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号