Method 1:
Query ($ SQL) ;}// combine the generated temporary backup files $ outfile = date ("Y-m-d "). ". SQL "; if (file_exists ($ dbdir. $ outfile) @ unlink ($ dbdir. $ outfile); $ fpr = fopen ($ dbdir. $ outfile, "a"); foreach ($ txtname as $ txt) {if (file_exists ($ dbdir. $ txt) {// read the temporary backup file $ tdata = readfiles ($ dbdir. $ txt); // generate the backup file $ tbl = explode (". ", $ txt); $ str = "'". $ tbl [0]. "'}"; if (fwrite ($ fpr, $ str) {echo $ tbl [0]. "... $ outfile written successfully!
N ";} else {echo $ tbl [0]."... failed to write $ outfile!
N ";}@ unlink ($ dbdir. $ txt) ;}} fclose ($ fpr);} else {// restore Data $ tdata = readfiles ($ dbdir. $ _ POST ["sqlfile"]); preg_match_all ("/'(. *) '}/isU ", $ tdata, $ data_ar); foreach ($ data_ar [1] as $ k => $ tt) {if (empty ($ data_ar [2] [$ k]) continue; $ tfile = $ dbdir. $ tt. ". txt "; $ fp = fopen ($ tfile," w "); if (fwrite ($ fp, $ data_ar [2] [$ k]) {// clear the TABLE $ SQL = "truncate table '$ tt'"; $ db-> query ($ SQL); // reload DATA $ SQL = "LOAD DATA LOW _ Priority infile '". $ dbdir. $ tt. ". txt ". "'into table' $ tt'"; if ($ db-> query ($ SQL) {fclose ($ fp); echo $ tt. "Table data recovery successful!
N "; unlink ($ dbdir. $ tt.". txt ");} else {echo $ tt." table data recovery failed!
N ";}}// echo $ tdata; // print_r ($ data_ar); // exit ;}} /** Read file Content * parameter $ file is the file name and complete path * returned file content */function readfiles ($ file) {$ tdata = ""; $ fp = fopen ($ file, "r"); if (filesize ($ file) <= 0) return; while ($ data = fread ($ fp, filesize ($ file) {$ tdata. = $ data ;}fclose ($ fp); return $ tdata ;}?>
Method 2:
I want to directly back up the database in the PHP background, so I have never thought of any idea. At the beginning, I was thinking about using php to access the directory where the server installed mysql, for example, in the/usr/local/mysql/data directory, the following files are directly backed up, but a problem occurs:
First, the user who runs php is an apche user. For example, if it is a nobody, it generally has no permission to access the/usr/local/mysql/data directory.
Second, even if you can access it, how can you copy the files in the/usr/local/mysql/data directory? Because mysql does not run access when it is running, the nobody user has the permission to stop mysql services, which is impossible!
The more I thought about the problem, the more I couldn't find a way to see if I could start to operate the database in php. So I checked phpMyadmin and Discuz! So I copied Discuz! The following method is used to back up the database. (Thanks to Discuz! Developers)
There are two ways to back up the database: one is to back up the structure of the database, the other is to back up the structure and all the data, of course, the second method is good, however, I have done everything to consider possible needs.