mysqldumpが使えないレンタルサーバでMySQLのバックアップ
2024/03/04
mysqldumpが使えないレンタルサーバで開発を行うことがあり、尚且つ他社に使ってもらうものなのでMySQLのバックアップは定期的に取っておきたかった。
無理やりだけどPHPでmysqldumpっぽい結果を出すような関数を作ったのでメモ。
ソースコード
//---------------------------------------- // [引数] // $table(string) テーブル名 // [返り値] // string or false //---------------------------------------- function getDump( $table = '' ){ if( !$table ){ return false; } //DB接続 $mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname); $mysqli->set_charset('utf8'); //カラム情報の取得 $sql = ' SHOW COLUMNS FROM `'.$table.'` '; $row = $mysqli->query($sql); if( !$row ){ return fasle; } while ($rs = $row->fetch_array(MYSQLI_ASSOC)) { $data['Field'][] = $rs['Field']; } //データの取得 $sql = ' SELECT * FROM `'.$table.'` '; $row = $mysqli->query($sql); if( !$row ){ return fasle; } while ($rs = $row->fetch_array(MYSQLI_ASSOC)) { $data['data'][] = $rs; } $return = 'INSERT INTO `'.$table.'` (`'.implode('`,`', $data['Field']).'`) VALUES '; foreach( $data['data'] as $key => $val ){ $return .= "('".implode("','", $val)."'),"; } $return = rtrim($return, ',') . ";\n"; return $return; }
使い方
DB接続の部分を適宜編集した上で、引数にテーブル名を渡せばOK。file_put_contentsとかでファイル化して、どこかのディレクトリに保存しておいたり、メールで送る形が良いかと。
あとはcronが使えるサーバからこのプログラムを定期的に参照させる。
尚、アクセスログみたく膨大な行数になるものは止めといた方がよさそう。
関連記事
-
-
お名前.comのレンタルサーバ(SDサーバ)にMySQLデータのインポートする方法
お名前.comのレンタルサーバにそこそこ大きいサイズのMySQLデータを移行した ...
-
-
MySQLでdatetime型のカラムから秒は省いて検索する方法
MySQLでdatetime型のカラムに対して「2022-10-07 10:30 ...
-
-
MySQLで開始から終了日付内を調べたいとき
等号不等号でもできるけど、BETWEENというのがよさそう。 ■参考サイト ht ...
-
-
MySQLでテーブルとデータの複製(コピー)する方法
MySQLでテーブルとデータを複製したかった。ダンプとかではなく、簡単なSQL文 ...
-
-
MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法
レンタルしているVPS内のファイルを整理していると「/var/lib/mysql ...