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でのクエリキャッシュ設定及び設定項目について以下にメモ。 ...
-
-
お名前.comのレンタルサーバ(SDサーバ)にMySQLデータのインポートする方法
お名前.comのレンタルサーバにそこそこ大きいサイズのMySQLデータを移行した ...
-
-
PHPからMySQLにシリアライズしたデータを格納
アンケートフォームみたいなのがあって、 今後も定期開催し、尚且つ質問内容は増減す ...
-
-
MySQLで特定のテーブルにパーティショニング設定し高速化を図る方法
以前に他社が設計されたログ系のテーブルを拝見した際にパーティショニング設定が行わ ...
-
-
MySQLに保存したデータをJSON形式で取得する方法
MySQLに保存したデータをJSON形式で利用したいということがたまにある(Ja ...