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が使えるサーバからこのプログラムを定期的に参照させる。
尚、アクセスログみたく膨大な行数になるものは止めといた方がよさそう。
関連記事
MySQLで全国の市区町村のデータを入手し、抽出する方法
都道府県と市区町村が連携したセレクトメニューを作成したかった。具体的には大阪府を ...
MySQLでテーブルとデータの複製(コピー)する方法
MySQLでテーブルとデータを複製したかった。ダンプとかではなく、簡単なSQL文 ...
MySQL/Apacheの再起動
忘れないようにメモ。 ■MySQL service mysqld restart ...
MySQLでユニークキーをはる
MySQLでseqとcodeみたいなものをあわせて ユニークキーをはりたかった。 ...
WordPressでデータベース接続確立エラー発生時の対応方法
WordPressで「データベース接続確立エラー」というエラー表示がされた。大抵 ...