MySQL データをバックアップするための PHP コード

WBOY
リリース: 2016-07-25 08:45:50
オリジナル
852 人が閲覧しました
  1. #####################
  2. //設定
  3. ############### #######
  4. // バックアップ ディレクトリの名前を定義します
  5. define('BACKUP_DIR', './myBackups' ) ;
  6. // データベース資格情報を定義します
  7. define('HOST', 'localhost' ) ;
  8. define('USER', 'testd!b' ) ;
  9. define('パスワード', 'k^$2y4n9@#VV' ) ;
  10. define('DB_NAME', 'test123' ) ;
  11. /*
  12. SQL ファイルのファイル名を定義します
  13. ファイルを Amazon の S3 サービスにアップロードする場合は、小文字のみを使用してください
  14. */
  15. $fileName = 'mysqlbackup--' 。 date('d-m-Y') 。 '@'.date('h.i.s').'.sql' ;
  16. // 実行時間制限を設定します
  17. if(function_exists('max_execution_time')) {
  18. if( ini_get('max_execution_time') > 0 ) set_time_limit(0) ;
  19. }
  20. ######## #################
  21. //設定終了
  22. ######################## ###
  23. // ディレクトリが既に作成されており、適切な権限があるかどうかを確認します
  24. if (!file_exists(BACKUP_DIR)) mkdir(BACKUP_DIR , 0700) ;
  25. if (!is_writable(BACKUP_DIR)) chmod(BACKUP_DIR , 0700) ;
  26. // ".htaccess" ファイルを作成します。これにより、バックアップ ディレクトリへの直接アクセスが制限されます。
  27. $content = 'すべてから拒否' ;
  28. $file = new SplFileObject(BACKUP_DIR . '/.htaccess', "w") ;
  29. $file->fwrite($content) ;
  30. $mysqli = new mysqli(HOST , USER , PASSWORD , DB_NAME) ;
  31. if (mysqli_connect_errno())
  32. {
  33. printf("Connect failed: %s", mysqli_connect_error());
  34. exit();
  35. }
  36. // 紹介情報
  37. $return .= "--n";
  38. $return .= "-- Mysql バックアップ システム n";
  39. $return .= "--n";
  40. $return .= '-- エクスポートが作成されました: ' . date("Y/m/d") 。 ' の上 ' 。 date("h:i") 。 "nnn";
  41. $return = "--n";
  42. $return .= "-- データベース : " . DB_NAME 。 "n";
  43. $return .= "--n";
  44. $return .= "-- ------------------------- -----------------------n";
  45. $return .= "------- ------------------------------------n";
  46. $return .= 'SET AUTOCOMMIT = 0 ;' ."n" ;
  47. $return .= 'SET FOREIGN_KEY_CHECKS=0 ;' ."n" ;
  48. $tables = array() ;
  49. // このデータベースにどのようなテーブルがあるかを調査します
  50. $result = $mysqli->query('SHOW TABLES' ) ;
  51. // "$result" を循環させ、コンテンツを配列に入れます
  52. while ($row = $result->fetch_row())
  53. {
  54. $tables[] = $row[0] ;
  55. }
  56. // Cycle各テーブルを通して
  57. foreach($tables as $table)
  58. {
  59. // 各テーブルの内容を取得します
  60. $result = $mysqli->query('SELECT * FROM '. $table) ;
  61. // 各テーブルのフィールド(列)数を取得
  62. $num_fields = $mysqli->field_count ;
  63. // テーブル情報を追加
  64. $return .= "--n" ;
  65. $return .= '-- Tabelテーブル `' の構造。 $テーブル 。 「」。 "n" ;
  66. $return .= "--n" ;
  67. $return.= 'DROP TABLE IF EXISTS `'.$table.'`;' 。 「ん」 ;
  68. // テーブルシェマを取得
  69. $shema = $mysqli->query('SHOW CREATE TABLE '.$table) ;
  70. // テーブルシェマを抽出
  71. $tableshema = $shema->fetch_row() ;
  72. // コードにテーブル シェマを追加します
  73. $return.= $tableshema[1].";" 。 「ん」 ;
  74. // 各テーブル行を循環します
  75. while($rowdata = $result->fetch_row())
  76. {
  77. // テーブルにデータを挿入するコードを準備します
  78. $return .= 'INSERT INTO `'.$table .'` VALUES ( ' ;
  79. // 各行のデータを抽出します
  80. for($i=0; $i{
  81. $return .= '"'.$rowdata[$i] . ""," ;
  82. }
  83. // 最後のカンマを削除しましょう
  84. $return = substr("$return", 0, -1) ;
  85. $return .= ");" ."n" ;
  86. }
  87. $return .= "nn" ;
  88. }
  89. // 接続を閉じます
  90. $mysqli->close() ;
  91. $return .= 'SET FOREIGN_KEY_CHECKS = 1 ; ' 。 「ん」 ;
  92. $return .= 'コミット ; ' 。 "n" ;
  93. $return .= 'SET AUTOCOMMIT = 1 ; ' 。 「ん」 ;
  94. //$file = file_put_contents($fileName , $return) ;
  95. $zip = new ZipArchive() ;
  96. $resOpen = $zip->open(BACKUP_DIR . '/' .$fileName.".zip" , ZIPARCHIVE::CREATE) ;
  97. if( $resOpen ){
  98. $zip ->addFromString( $fileName , "$return" ) ;
  99. }
  100. $zip->close() ;
  101. $fileSize = get_file_size_unit(filesize(BACKUP_DIR . "/". $fileName . '.zip')) ;
  102. $message = <<

    バックアップが完了しました、


  103. アーカイブの名前は次のとおりです: $ファイル名 ファイルサイズは $fileSize です。
  104. この zip アーカイブは保護されたディレクトリに保存されているため、Web ブラウザからはアクセスできません。
  105. このバックアップを別のファイルシステムに転送し、お気に入りの FTP クライアントを使用してアーカイブをダウンロードすることを強くお勧めします。
  106. msg;
  107. echo $message ;
  108. // file-size の後に適切な Unit を追加する関数。
  109. function get_file_size_unit($file_size){
  110. switch (true) {
  111. case ($file_size/1024 return intval($file_size ) ." バイト" ;
  112. Break;
  113. case ($file_size/1024 > = 1 && $file_size/(1024*1024) < 1) :
  114. return intval($file_size/1024) ." KB" ;
  115. ブレーク;
  116. デフォルト:
  117. return intval($file_size/(1024*1024)) 。 " MB" ;
  118. }
  119. }
复制代

mysql、php


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート