วัน: 23 มกราคม 2019
ซ่อมฐานข้อมูลMysql
การตรวจสอบและซ่อมแซม Databases บน Windows และ Linux
mysqlcheck -u “user” -p –auto-repair –all-database
ตรวจสอบและซ่อมแซม Database ทั้งหมด
ถ้า Databses เป็น myisam สามารถใช้คำสั่งนี้ โดยตรงกับไฟล์ตารางในฐานได้
#myisamchk -r *.MYI
ตรวจสอบตารางทั้งหมดในฐานข้อมูล
กรณีที่ต้องการตรวจสอบและซ่อมแซมเฉพาะบางตาราง
mysql -p
use db_name;
#ตรวจสอบตารางที่ต้องการ
check table table_name;
#ซ่อมตารางที่ต้องการ
repair table table_name;
การสำรองฐานข้อมูลMysql
วิธี Backup และ Restore ฐานข้อมูล Mysql ด้วย Command line วิธีสำรองฐานข้อมูล Mysql และ วิธีนำข้อมูลที่สำรองไว้กลับมาใช้ใหม่ (Import)
วิธีสำรองฐานข้อมูล Mysql (ฺBackup)
– การสำรองฐานข้อมูล ด้วย Command line เหมาะสำหรับการสำรองฐานข้อมูลที่มีขนาดใหญ่ซึ่งไม่สามารถทำได้ด้วย phpMyAdmin
– mysqldump เป็นโปรแกรมสำหรับทำหน้าที่สำรองฐานข้อมูล mysql เมื่อเราติดตั้ง Mysql Server ก็จะได้มันมาด้วย มาดูวิธีใช้ mysqldump ก่อนอื่นให้เข้าหน้าจอ Command Prompt ให้เรียบร้อยก่อน
รูปแบบในการสำรองฐานข้อมูล
$ mysqldump –opt -u [uname] -p[pass] [dbname] > [backupfile.sql
โดยที่
[uname] คือชื่อผู้ใช้งานฐานข้อมูล
[pass] คือรหัสผ่านของชื่อผู้ใช้งารฐานข้อมูล
[dbname] คือชื่อฐานข้อมูลที่ต้องการสำรองข้อมูล
[backupfile.sql] คือชื่อไฟล์ที่ต้องการ
–opt คือ option ของการสำรองฐานข้อมูลเช่น การกำหนดเรื่องภาษา, เวอร์ชั่น
ตัวอย่างการใช้งาน
– การสำรองฐานข้อมูล mindphp ทั้งก้อน
$ mysqldump -u root -p mindphp > mindphp_backup.sql
จากตัวอย่าง หมายความว่า ใช้ user root ในการสำรองฐานข้อมูลที่ชื่อ mindphp เก็บไว้ใน ไฟล์ mindphp_backup.sql
– การสำรองฐานข้อมูล mindphp เฉพาะ บางตาราง
$ mysqldump -u root -p mindphp tb_users tb_tutorials > mindphp_sametable_backup.sql
– การสำรองฐานข้อมูลหลายๆ ก้อนพร้อมกัน
$ mysqldump -u root -p –databases db1 db2 db3 > dbs_backup.sql
– การสำรองฐานข้อมูลทุกก้อนในคำสั่งเดียว
$ mysqldump -u root -p –all-databases > alldb_backup.sql
– การสำรองฐานข้อมูลพร้อมทั้งบีบอัดไฟล์ที่ได้
$ mysqldump -u [uname] -p[pass] [dbname] | gzip -9 > [backupfile.sql.gz]
ตัวอย่าง option ในการสำรองฐานข้อมูล
–add-drop-table: บอกให้ mysqldump เพิ่มคำสั่ง DROP TABLE ก่อนคำสั่ง CREATE TABLE เพื่อให้เวลาเรา restore ฐานข้อมูลกลับถ้า ถ้ามีตารางเดิมอยู่มันจะลบตารางเดิมออกก่อนแล้วสร้างตารางให้ใหม่พร้อมทั้งเอาข้อมูใส่ให้ที่ตารางนั้น
–no-data: เป็นการสำรองฐานข้อมูลเฉพาะโครงสร้างฐานข้อมูล โดยไม่ได้เอาข้อมูลมาด้วย
–add-locks: เป็นการเพิ่มคำสั่ง LOCK TABLES และ UNLOCK TABLES ตอนที่เรา backup restore
การ Restore หรือ การ Import ข้อมูลที่สำรองไว้นำกลับมาใช้ใหม่
$ mysql -u [uname] -p[pass] [mindphp] < [mindphp_backupfile.sql]
จากตัวอย่างคำสั่ง หมายความว่า เราจะ import ไฟล์ mindphp_backupfile.sql กลับไปที่ฐานข้อมูลที่ชื่อ mindphp