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のTEMPORARY TABLE(テンポラリテーブル)で高速化を図る方法
MySQLで5000万件ぐらいデータが入っているテーブルから日本語検索しないとい ...
-
-
MySQLでINSERT時にオートインクリメントではないカラムに連番を登録する方法
MySQLでINSERT時にオートインクリメントではないカラムに連番を登録したい ...
-
-
MySQLにてSELECT時にdate型のカラムから年齢を計算し取得する方法
MySQLにdate型のカラムに誕生年月日が格納されており、そこから年齢を計算し ...
-
-
phpmyadminからプロセスの停止
重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...
-
-
MySQLで「server has gone~」というエラーの対応方法
MySQLで「MySQL server has gone away」というエラー ...