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で直近に挿入したオートインクリメントの値と次回挿入する値を取得する方法
phpとmysqliを使っている中で次回挿入するオートインクリメントの値と、前回 ...
-
-
MySQLでCSVから列を指定してインポート
MySQLでCSVからデータをインポートしたかった。またエクセル風にいうA列はi ...
-
-
MySQLにてSELECT時にdate型のカラムから和暦を計算し表示する方法
MySQLにdate型のカラムに誕生年月日が格納されており、そこから和暦を計算し ...
-
-
ON DUPLICATE KEY UPDATE後にinsert_idを取得すると結果が0になる
MySQLでON DUPLICATE KEY UPDATE句指定し、データの登録 ...
-
-
MySQLで開始~終了日時の間隔を計算し分に変換して出力する方法
MySQLで「開始日時」「終了日時」のdatetime型カラムがあり、開始から終 ...