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でデータの集計時に1日の起点を任意の時間に変更する方法
MySQLで1日毎の集計を行う際、例えば2020/01/01のデータは2020/ ...
-
-
MySQLにてSELECT時にdate型のカラムから和暦を計算し表示する方法
MySQLにdate型のカラムに誕生年月日が格納されており、そこから和暦を計算し ...
-
-
MySQLでROW_NUMBER関数を使用してグループ毎に連番を設定する方法
以前にMySQLでオートインクリメントを使用せずにグループ毎に連番を設定する方法 ...
-
-
MySQLでユーザー作成時にエラーが発生
SSHからrootアカウントでMySQLにログインし、ユーザーを作成しようとする ...
-
-
PHP / MySQLで2038年問題の対策
先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...