A file-per-table tablespace contains data and indexes for a single
InnoDB table, and is stored on the file system
in a single data file.
File-per-table tablespace characteristics are described under the following topics in this section:
InnoDB creates tables in file-per-table
tablespaces by default. This behavior is controlled by the
InnoDB to create tables in the system
setting can be specified in an option file or configured at
runtime using a
GLOBAL statement. Changing the setting at runtime
requires privileges sufficient to set global system variables.
See Section 22.214.171.124, “System Variable Privileges”.
GLOBAL at runtime:
mysql> SET GLOBAL innodb_file_per_table=ON;
enabled by default in MySQL 5.6 and higher. You might consider
disabling it if backward compatibility with earlier versions of
MySQL is a concern.
TABLE operations from implicitly moving a table that
resides in the system tablespace to a file-per-table
tablespace. A table-copying
TABLE operation recreates the table using the
setting. This behavior does not apply when adding or dropping
secondary indexes, nor does it apply to
ALTER TABLE operations that use
A file-per-table tablespace is created in an
.ibd data file in a schema directory under
the MySQL data directory. The
.ibd file is
named for the table
For example, the data file for table
is created in the
test directory under the
MySQL data directory:
mysql> USE test; mysql> CREATE TABLE t1 ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(100) ) ENGINE = InnoDB; $> cd /path/to/mysql/data/test $> ls t1.ibd
You can use the
DATA DIRECTORY clause of the
CREATE TABLE statement to
implicitly create a file-per-table tablespace data file outside
of the data directory. For more information, see
Section 126.96.36.199, “Creating Tables Externally”.
File-per-table tablespaces have the following advantages over the shared system tablespace.
Disk space is returned to the operating system after truncating or dropping a table created in a file-per-table tablespace. Truncating or dropping a table stored in the system tablespace creates free space within the system tablespace, which can only be used for
InnoDBdata. In other words, a system tablespace does not shrink in size after a table is truncated or dropped.
ALTER TABLEoperation on a table that resides in the system tablespace can increase the amount of disk space occupied by the tablespace. Such operations may require as much additional space as the data in the table plus indexes. This space is not released back to the operating system as it is for file-per-table tablespaces.
TRUNCATE TABLEperformance is better when executed on tables that reside in file-per-table tablespaces.
File-per-table tablespace data files can be created on separate storage devices for I/O optimization, space management, or backup purposes. See Section 188.8.131.52, “Creating Tables Externally”.
You can import table that resides in a file-per-table tablespace from another MySQL instance. See Section 184.108.40.206, “Importing InnoDB Tables”.
Tables created in file-per-table tablespaces use the Barracuda file format. See Section 14.10, “InnoDB File-Format Management”. The Barracuda file format enables features associated with
COMPRESSEDrow formats. See Section 14.11, “InnoDB Row Formats”.
Tables stored in individual tablespace data files can save time and improve chances for a successful recovery when data corruption occurs, when backups or binary logs are unavailable, or when the MySQL server instance cannot be restarted.
Tables created in file-per-table tablespaces cab be backed up or restored quickly using MySQL Enterprise Backup, without interrupting the use of other
InnoDBtables. This is beneficial for tables on varying backup schedules or that require backup less frequently. See Making a Partial Backup for details.
File-per-table tablespaces permit monitoring table size on the file system by monitoring the size of the tablespace data file.
Common Linux file systems do not permit concurrent writes to a single file such as a system tablespace data file when
innodb_flush_methodis set to
O_DIRECT. As a result, there are possible performance improvements when using file-per-table tablespaces in conjunction with this setting.
Tables in the shared system tablespace, which contains other structures such as the
InnoDBdata dictionary and undo logs, are limited in size by the 64TB tablespace size limit. By comparison, each file-per-table tablespace has a 64TB size limit, which provides plenty of room for individual tables to grow in size.
File-per-table tablespaces have the following disadvantages compared to the shared system tablespace.
With file-per-table tablespaces, each table may have unused space that can only be utilized by rows of the same table, which can lead to wasted space if not properly managed.
fsyncoperations are performed on multiple file-per-table data files instead of a shared system tablespace data file. Because
fsyncoperations are per file, write operations for multiple tables cannot be combined, which can result in a higher total number of
mysqld must keep an open file handle for each file-per-table tablespace, which may impact performance if you have numerous tables in file-per-table tablespaces.
More file descriptors are required when each table has its own data file.
There is potential for more fragmentation, which can impede
DROP TABLEand table scan performance. However, if fragmentation is managed, file-per-table tablespaces can improve performance for these operations.
The buffer pool is scanned when dropping a table that resides in a file-per-table tablespace, which can take several seconds for large buffer pools. The scan is performed with a broad internal lock, which may delay other operations.
innodb_autoextend_incrementvariable, which defines the increment size for extending the size of an auto-extending system tablespace file when it becomes full, does not apply to file-per-table tablespace files, which are auto-extending regardless of the
innodb_autoextend_incrementsetting. Initial file-per-table tablespace extensions are by small amounts, after which extensions occur in increments of 4MB.