CHECK TABLE
Check tables or views for errors. This statement verifies the integrity of table structure and data for supported storage engines.
Syntax
CHECK TABLE tbl_name [, tbl_name] ... [option] ...
option = {FOR UPGRADE | QUICK | FAST | MEDIUM | EXTENDED | CHANGED}Description
CHECK TABLE checks a table or tables for errors. CHECK TABLE works for Archive, Aria, CSV, InnoDB, MyISAM, and, from MariaDB 12.0, Sequence tables. For Aria and MyISAM tables, the key statistics are updated as well. For CSV, see also Checking and Repairing CSV Tables.
As an alternative, myisamchk is a command-line tool for checking MyISAM tables when the tables are not being accessed. For Aria tables, there is a similar tool: aria_chk.
For checking dynamic columns' integrity, COLUMN_CHECK() can be used.
CHECK TABLE can also check views for problems, such as tables that are referenced in the view definition that no longer exist.
CHECK TABLE is also supported for partitioned tables. You can use ALTER TABLE ... CHECK PARTITION to check one or more partitions.
The meaning of the different options is as follows - note that this can vary a bit between storage engines:
FOR UPGRADE
Do a very quick check if the storage format for the table has changed so that one needs to do a REPAIR. This is only needed when one upgrades between major versions of MariaDB or MySQL. This is usually done by running mariadb-upgrade.
FAST
Only check tables that has not been closed properly or are marked as corrupt. Only supported by the MyISAM and Aria engines. For other engines the table is checked normally
CHANGED
Check only tables that have changed since the last REPAIR / CHECK. Only supported by the MyISAM and Aria engines. For other engines, the table is checked normally.
QUICK
Do a fast check. For MyISAM and Aria, this means skipping the check of the delete link chain, which may take some time.
MEDIUM
Scan also the data files. Checks the integrity between data and index files with checksums. In most cases, this should find all possible errors.
EXTENDED
Does a full check to verify every possible error. For InnoDB, Aria, and MyISAM, verify for each row that all its keys exist, and for those index keys, they point back to the primary clustered key. This may take a long time on large tables.
The EXTENDED option is available to InnoDB, too.
The EXTENDED option is ignored by InnoDB.
When the EXTENDED option is given, MariaDB also checks for referential integrity.
MariaDB does not check for referential integrity, even if the EXTENDED option is given.
For most cases, running CHECK TABLE without options or MEDIUM should be good enough.
The Aria storage engine supports progress reporting for this statement.
If you want to know if two tables are identical, take a look at CHECKSUM TABLE.
InnoDB
If CHECK TABLE finds an error in an InnoDB table, MariaDB might shut down to prevent the error propagation. In this case, the problem will be reported in the error log. Otherwise, the table or an index might be marked as corrupted, to prevent use. This does not happen with some minor problems, like a wrong number of entries in a secondary index. Those problems are reported in the output of CHECK TABLE.
Each tablespace contains a header with metadata. This header is not checked by this statement.
During the execution of CHECK TABLE, other threads may be blocked.
Examples
CHECK TABLE y EXTENDED;
+--------+-------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+--------+-------+----------+----------+
| test.y | check | status | OK |
+--------+-------+----------+----------+In newer MariaDB versions, the EXTENDED clause provides more information:
CHECK TABLE t1 EXTENDED;
+---------+-------+----------+----------------------------------------------------------------------+
| Table | Op | Msg_type | Msg_text |
+---------+-------+----------+----------------------------------------------------------------------+
| test.t1 | check | Warning | No suitable key found for foreign key t2_ibfk_1 in table test.t1 |
+---------+-------+----------+----------------------------------------------------------------------+
CHECK TABLE t2 EXTENDED;
+---------+-------+----------+--------------------------------------------------------------------------------------------------+
| Table | Op | Msg_type | Msg_text |
+---------+-------+----------+--------------------------------------------------------------------------------------------------+
| test.t2 | check | status | Cannot add or update a child row: a foreign key constraint fails (Key: t2_ibfk_1, record: '2') |
| test.t2 | check | status | Cannot add or update a child row: a foreign key constraint fails (Key: t2_ibfk_1, record: '2') |
| test.t2 | check | status | Cannot add or update a child row: a foreign key constraint fails (Key: t2_ibfk_1, record: '3') |
| test.t2 | check | error | Corrupt |
+---------+-------+----------+--------------------------------------------------------------------------------------------------+This page is licensed: GPLv2, originally from fill_help_tables.sql
Last updated
Was this helpful?

