วิธีสำรองฐานข้อมูล 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 ของการสำรองฐานข้อมูลเช่น การกำหนดเรื่องภาษา, เวอร์ชั่น
ตัวอย่างการใช้งาน
- การสำรองฐานข้อมูล artwancom ทั้งก้อน
$ mysqldump -u root -p artwancom > artwancom_backup.sql
จากตัวอย่าง หมายความว่า ใช้ user root ในการสำรองฐานข้อมูลที่ชื่อ artwancom เก็บไว้ใน ไฟล์ artwancom_backup.sql
- การสำรองฐานข้อมูล artwancom เฉพาะ บางตาราง
$ mysqldump -u root -p artwancom tb_users tb_tutorials > artwancom_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] [artwancom] < [artwancom_backupfile.sql]
จากตัวอย่างคำสั่ง หมายความว่า เราจะ import ไฟล์ artwancom_backupfile.sql กลับไปที่ฐานข้อมูลที่ชื่อ artwancom
$ mysql -u root -p < artwancom_backup.sql
เท่านี้ฐานข้อมูลขนาดใหญ่ ระดับ หลายร้อย MB ก็ไม่ใช่ปัญหาในการ backup, และ restore อีกต่อไปครับ