MySQL is a relational database management system based on the Structured Query Language, which is the popular language for accessing and managing the records in the database. MySQL is open-source and free software under the GNU license. It is supported by Oracle Company.
Database corruption is not always as simple as a "database corrupted" error message. We can only act based on the symptoms that suggest database corruption. The corruption may be limited to a single table, a data block, or a single entry.
Common causes of database corruption are:
Server hardware failure.
Unexpected machine shutdown.
The MySQL server stopped in the middle of a write.
Using 3rd party software to access the database
Software bugs within the MySQL code.
Wrong data schema.
Backing up MySQL Data
Stop MySQL database using the following command.
# systemctl stop mysqld
data:image/s3,"s3://crabby-images/9f38b/9f38bf2a4ec5856c79bf6efad4d1bdfa04254d21" alt="repairmysqldb1"
Create a backup now.
# cp -r /var/lib/mysql /var/lib/mysql_backup
data:image/s3,"s3://crabby-images/97eb4/97eb4f330b3311eafcc7bd170bda288da418ca1b" alt="repairmysqldb2"
Restart the MySQL database.
# systemctl start mysqld
data:image/s3,"s3://crabby-images/687cc/687cc5a9b3dd598cb3064a32997ae94d1f1ce6d9" alt="repairmysqldb3"
Finding MySQL Engine Type
Log in to MySQL using username and password.
# mysql -u root -p
data:image/s3,"s3://crabby-images/201ac/201acef54747c729210090fef726a6f82cc3b74d" alt="repairmysqldb4"
List the databases in MySQL.
SHOW DATABASES;
data:image/s3,"s3://crabby-images/e79de/e79de3e6e93d00f268f495556b92ca969851d706" alt="repairmysqldb5"
Use the following command to know the database table engine. If it is InnoDB or MyISAM.
SELECT TABLE_NAME, ENGINE FROM information_schema.TABLES where TABLE_SCHEMA = 'layerstack_innodb';
SELECT TABLE_NAME, ENGINE FROM information_schema.TABLES where TABLE_SCHEMA = 'layerstack_myisam';
data:image/s3,"s3://crabby-images/f84c9/f84c9ec90983c49b46f8aa95a6653153ed1e4519" alt="repairmysqldb6"
Repairing MyISAM Tables
Select layerstack_myisam database using the following command.
USE layerstack_myisam;
data:image/s3,"s3://crabby-images/f753a/f753ad6627b2fe4b7cafbcbb297c05840be24b33" alt="repairmysqldb7"
Check for corruption on tables running the MyISAM storage engine, such as the customer's table above, using the following MySQL prompt.
CHECK TABLE layerstack_myisam;
data:image/s3,"s3://crabby-images/bbb4f/bbb4f9eba5e9e2bb5e400eb1d680e4215387b98b" alt="repairmysqldb8"
Use the following command to repair myisam table.
REPAIR TABLE layerstack_myisam;
data:image/s3,"s3://crabby-images/cf7c4/cf7c4912495809a13f97586c0368a4c44aca1cce" alt="repairmysqldb9"
Repairing MySQL Database with mysqlcheck
The mysqlcheck command is an alternative to repairing database tables in the terminal.
Change directory to /var/lib/mysql.
# cd /var/lib/mysql
data:image/s3,"s3://crabby-images/342c7/342c7fa303199f0eadd83443c46df085db5bc296" alt="repairmysqldb10"
Use mysqlcheck command.
# mysqlcheck -u root -p --safe --recover <database> <tablename>
data:image/s3,"s3://crabby-images/57bb4/57bb4930753962bc32fe41c10491d295db6a3523" alt="repairmysqldb11"
Repairing InnoDB Tables
Start InnoDB recovery, use the following command to edit mysqld.cnf file.
# vim /etc/my.cnf
data:image/s3,"s3://crabby-images/b0791/b079117308b4847e63f93f36e5f3d49c9c3da4e7" alt="repairmysqldb12"
And add the following
innodb_force_recovery=1
data:image/s3,"s3://crabby-images/1b79e/1b79e9aef1d29887f3a6e2b95b10812eab9c4416" alt="repairmysqldb13"
By default, the forced recovery option is set to 0 (off) and goes up to 6. Every new level includes the recovery features of the lower numbers.
Restart the MySQL service.
# systemctl restart mysqld
data:image/s3,"s3://crabby-images/37548/375489c600198a258043e90e2b707ef10537a2e2" alt="repairmysqldb14"
Create mysqldump of layerstack_innodb database.
# mysqldump -u root -p --routines --triggers --events layerstack_innodb > backup_db.sql
data:image/s3,"s3://crabby-images/1c75b/1c75bdf073c116ef797ba58208b7487aee8f786a" alt="repairmysqldb15"
The next step is to drop the table from the database.
# mysql -u root -p --execute="DROP TABLE layerstack_innodb.layerstack_innodb"
data:image/s3,"s3://crabby-images/af278/af2789fd884e6a584c7992560b715a8d87419e9c" alt="repairmysqldb16"
Restore the table.
# mysql -u root -p layerstack_innodb < backup_db.sql
data:image/s3,"s3://crabby-images/76535/765351f2aaf1e6a1a49d38f226a384a8ed124ea4" alt="repairmysqldb17"
This tutorial demonstrated how to fix a corrupted MySQL table running the MyISAM or InnoDB storage engines.
Related Tutorials