Sao lưu (Backup) MySQL sử dụng PHP



Tạo một bản sao lưu (backup) của Database luôn luôn là một bài thực hành tốt. Có 3 cách bạn có thể sử dụng để sao lưu MySQL Database của bạn:

  • Sử dụng SQL Command thông qua PHP.
  • Sử dụng MySQL Binary mysqldump thông qua PHP.
  • Sử dụng phpMyAdmin User Interface.

Sử dụng SQL Command thông qua PHP

Bạn có thể thực thi lệnh SQL SELECT để tạo một bản sao lưu của bất kỳ Table nào. Để sao lưu đầy đủ Database, bạn sẽ cần viết truy vấn riêng biệt cho mỗi Table riêng. Mỗi Table sẽ được lưu giữ vào trong text file riêng biệt.

Ví dụ

Bạn thử ví dụ sau sử dụng truy vấn SELECT INTO OUTFILE để tạo bản sao lưu của Table.

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'tennguoidung';
   $dbpass = 'matkhau';
   
   $conn = mysql_connect($dbhost, $dbuser, $dbpass);
   
   if(! $conn )
   {
      die('Không thể kết nối: ' . mysql_error());
   }
	
   $table_name = "employee";
   $backup_file  = "/tmp/employee.sql";
   $sql = "SELECT * INTO OUTFILE '$backup_file' FROM $table_name";
   
   mysql_select_db('test_db');
   $retval = mysql_query( $sql, $conn );
   
   if(! $retval )
   {
      die('Không thể thực hiện hoạt động backup: ' . mysql_error());
   }
   
   echo "Backup dữ liệu thành công\n";
   
   mysql_close($conn);
?>
Quảng cáo

Có thể có tình huống khi bạn cần phục hồi dữ liệu mà bạn đã sao lưu trước đó. Để phục hồi bản backup đó, bạn chỉ cần chạy truy vấn LOAD DATA INFILE như thế này:

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'tennguoidung';
   $dbpass = 'matkhau';
   
   $conn = mysql_connect($dbhost, $dbuser, $dbpass);
   
   if(! $conn )
   {
      die('Không thể kết nối: ' . mysql_error());
   }
	
   $table_name = "employee";
   $backup_file  = "/tmp/employee.sql";
   $sql = "LOAD DATA INFILE '$backup_file' INTO TABLE $table_name";
   
   mysql_select_db('test_db');
   $retval = mysql_query( $sql, $conn );
   
   if(! $retval )
   {
      die('Không thể tải dữ liệu : ' . mysql_error());
   }
   echo "Tải dữ liệu thành công\n";
   
   mysql_close($conn);
?>

Sử dụng MySQL Binary mysqldump thông qua PHP

MySQL cung cấp một tiện ích mysqldump để thực hiện sao lưu Database. Sử dụng Binary này, bạn có thể sao lưu cả Database trong một lệnh đơn.

Ví dụ

Bạn thử ví dụ sau để sao lưu cả Database:

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'tennguoidung';
   $dbpass = 'matkhau';
   
   $backup_file = $dbname . date("Y-m-d-H-i-s") . '.gz';
   $command = "mysqldump --opt -h $dbhost -u $dbuser -p $dbpass ". "test_db | gzip > $backup_file";
   
   system($command);
?>
Quảng cáo

Sử dụng phpMyAdmin User Interface

Nếu bạn có phpMyAdmin User Interface có sẵn, thì để tạo một bản backup của Database là công việc rất dễ dàng.

Để sao lưu MySQL Database của bạn bởi sử dụng phpMyAmin, bạn nhấn vào "export" liên kết tới phpMyAmin main page. Chọn Database bạn muốn backup, kiểm tra các tùy chọn SQL thích hợp và nhập tên cho backup file.

Đã có app VietJack trên điện thoại, giải bài tập SGK, SBT Soạn văn, Văn mẫu, Thi online, Bài giảng....miễn phí. Tải ngay ứng dụng trên Android và iOS.

Theo dõi chúng tôi miễn phí trên mạng xã hội facebook và youtube:

Các bạn ở Hà Nội có thể tham gia khóa học thứ 9 của vietjackteam (đang tuyển sinh) vào cuối tháng 10/2018 do anh Nguyễn Thanh Tuyền, admin vietjack.com trực tiếp giảng dạy tại Hà Nội. Chi tiết nội dung khóa học tham khỏa link : Khóa học Java.Các bạn học CNTT, điện tử viễn thông, đa phương tiện, điện-điện tử, toán tin có thể theo học khóa này. Số lượng các công việc Java hoặc .NET luôn gấp ít nhất 3 lần Android hoặc iOS trên thị trường tuyển dụng. Khóa online= Đi phỏng vấn, Khóa offline= Đi phỏng vấn+ 1.5 tháng thực tập ngoài doanh nghiệp.

Mọi người có thể xem demo nội dung khóa học tại địa chỉ Video demo khóa học Offline

Các bạn ở xa học không có điều kiện thời gian có thể tham dự khóa Java online để chủ động cho việc học tập. Từ tháng 4/2018, VietJack khuyến mại giá SỐC chỉ còn 250k cho khóa học, các bạn có thể trả lại tiền nếu không hài lòng về chất lượng trong 1 tháng, liên hệ facebook admin fb.com/tuyen.vietjack để thanh toán chuyển khoản hoặc thẻ điện thoại, khóa học bằng Tiếng Việt với gần 100 video, các bạn có thể chủ động bất cứ lúc nào, và xem mãi mãi. Thông tin khóa học tại Khóa học Java Online trên Udemy

Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.

Các bài học PHP phổ biến khác tại VietJack:


php_va_mysql.jsp


Tài liệu giáo viên