ホームページ  >  記事  >  バックエンド開発  >  php mysql データベースのバックアップとデータ復元 class_PHP チュートリアル

php mysql データベースのバックアップとデータ復元 class_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 17:04:40761ブラウズ

説明: このタイプは、小規模な Web サイトのデータベースのバックアップに適しています。MYSQL 接続が組み込まれており、データ接続の簡単な設定のみが必要です。 * およびバックアップが保存される場所。 * クラスがインスタンス化され、データベースに接続された後、次の操作を実行できます。

php チュートリアル mysql チュートリアル データベース チュートリアル バックアップとデータ復元のクラス
/**
* このタイプは、mysql 接続が組み込まれており、データ接続の簡単な設定のみが必要なため、小規模な Web サイトのデータベースのバックアップに適していることに注意してください。 * およびバックアップが保存される場所。
* クラスがインスタンス化され、データベースに接続された後、次の操作を実行できます
* get_db_table($database) すべてのデータテーブルを取得します
* export_sql($table,$subsection=0)) SQL ファイルを生成します。生成された SQL ファイルはサーバー ディレクトリに保存されるだけで、ダウンロードには使用できないことに注意してください。 * import_sql($dir) 復元されたデータは、サーバー ディレクトリ内の SQL ファイルのみをインポートします
* このカテゴリは簡単に作成でき、自由に拡散できます。このカテゴリに関するご提案がございましたら、Xiaoxia までメールをお送りください。 * @著者のZhao Honjian[Youtian Xiaoxia]
*メール:328742379@qq.com
* QQ通信グループ: 69574955 Juyitang-ウェブページ制作通信
​*/


クラスデータ{

public $data_dir = "class/" //バックアップファイルが保存されるパス
; public $transfer =""; // SQL を一時的に保存します [この属性に値を割り当てないでください。そうでない場合、不正な SQL ステートメントが生成されます]


/**
*データベース接続

*@param string $host データベースのホスト名

*@param string $user ユーザー名
*@param string $pwd パスワード
*@param string $db データベース名を選択します
*@param string $charset エンコード方式
​*/
function connect_db($host,$user,$pwd,$db,$charset='gbk'){
if(!$conn = mysql_connect($host,$user,$pwd)){
false を返します;
}
mysql_select_db($db);
mysql_query("セット名 $charset");
true を返します;
}

/**
* SQL文を生成します

* @param $table バックアップするテーブル

* @return $tabledump
によって生成されたSQL文 ​*/
パブリック関数 set_sql($table,$subsection=0,&$tabledom=''){
$tabledom .= "$tablen が存在する場合はテーブルを削除";
$createtable = mysql_query("show create table $table");
$create = mysql_fetch_row($createtable);
$create[1] = str_replace("n","",$create[1]);
$create[1] = str_replace("t","",$create[1]);

$tabledom .= $create[1].";n";

$rows = mysql_query("select * from $table");

$numfields = mysql_num_fields($rows);

$numrows = mysql_num_rows($rows);

$n = 1;
$sqlarry = array();
while ($row = mysql_fetch_row($rows)){
$comma = "";
$tabledom .= "$table 値に挿入(";
for($i = 0; $i {
$tabledom .= $comma."'".mysql_escape_string($row[$i])."'";
$comma = ",";
}
$tabledom .= ")n";
If($subsection != 0 && strlen($this->transfer )>=$subsection*1000){
$sqlarry[$n]= $tabledom;
$テーブルダム = ''; }
}
$sqlarry を返します;
}

/**
*データベース内のテーブルを一覧表示します
*@param database $database 操作対象のデータベース名

*@return array $dbarray リストされたデータベーステーブル

​*/
パブリック関数 get_db_table($database){
$result = mysql_list_tables($database);
while($tmparry = mysql_fetch_row($result)){
$dbarry[] = $tmparry[0];
}
$dbarry を返します;
}

/**
*ディレクトリが有効かどうかを確認してください
*@param ディレクトリ $dir
*@return booln
​*/
関数 check_write_dir($dir){
if(!is_dir($dir)) {@mkdir($dir, 0777);}
if(is_dir($dir)){
if($link = opendir($dir)){
$filearry = scandir($dir);
for($i=0;$i If($filearry[$i]!='.' || $filearry != '..'){
@unlink($dir.$filearry[$i]);
}
}
}
}
true を返します;
}
/**
*データをファイルに書き込む
*@param file $filename ファイル名
*@param string $str 書き込む情報
*@return booln 書き込みが成功した場合は true を返し、それ以外の場合は false を返します
​*/
プライベート関数 write_sql($filename,$str){
$re= true;
if(!@$fp=fopen($filename,"w+")) {$re=false; echo "ファイルを開くときにエラーが発生しました。バックアップは失敗しました!";}
if(!@fwrite($fp,$str)) {$re=false; echo "情報の書き込み中にエラーが発生したため、バックアップに失敗しました!";}
if(!@fclose($fp)) {$re=false; echo "ファイルを閉じるときにエラーが発生しました。バックアップは失敗しました!";}
$re を返します;
}

/**
*SQLファイルを生成します
*@param string $sql SQL ステートメント
*@param 番号 $subsection サブセクションのサイズ (kb 単位)、0 はサブセクションがないことを意味します
​*/
     パブリック関数export_sql($table,$subsection=0){
      if(!$this->check_write_dir($this->data_dir)){echo '您没有权制限操作目录,备份失败';return false;}
      if($subsection == 0){
       if(!is_array($table)){
    $this->set_sql($table,0,$this->transfer);
   }その他{
    for($i=0;$i      $this->set_sql($table[$i],0,$this->transfer);
    }
   }
       $filename = $this->data_dir.date("ymd",time()).'_all.sql';
       if(!$this->write_sql($filename,$this->transfer)){return false;}
      }その他{
       if(!is_array($table)){
    $sqlarry = $this->set_sql($table,$subsection,$this->transfer);
    $sqlarry[] = $this->transfer;
   }その他{
    $sqlarry = array();
    for($i=0;$i      $tmparry = $this->set_sql($table[$i],$subsection,$this->transfer);
     $sqlarry = array_merge($sqlarry,$tmparry);
    }
    $sqlarry[] = $this->transfer;
   }
       for($i=0;$i         $filename = $this->data_dir.date("ymd",time()).'_part'.$i.'.sql';
        if(!$this->write_sql($filename,$sqlarry[$i])){return false;}
       }
      }
      true を返します;
    }
/**
*SQLファイルをロードします
*@param ディレクトリ $dir
*@return booln
*注意: ディレクトリの下に他のファイルやディレクトリを保存しないでください
*回復時間を節約するため
​*/
    パブリック関数 import_sql($dir){
  if($link = opendir($dir)){
   $filearry = scandir($dir);
    $pattern = "_part[0-9]+.sql$|_all.sql$";
   for($i=0;$i     if(エレギ($pattern,$filearry[$i])){
     $sqls=file($dir.$filearry[$i]);
     foreach($sqls as $sql){
      str_replace("r","",$sql);
      str_replace("n","",$sql);
      if(!mysql_query(trim($sql))) return false;
     }
    }
   }
   true を返します;
  }
    }

}

应用方法

//$d = 新しいデータ();

//连接データ库
//if(!$d->connect_db('localhost','root','','guestbook','gbk')){
// echo '数据库连接失败';
//}

//查找データベース库内のすべてのデータテーブル
//$tablearry = $d->get_db_table('ゲストブック');

//备份并生成sql文件
//if(!$d->export_sql($tablearry)){
// echo '备份失败';
//}その他{
// echo '备份成功';
//}

//恢复导入sql文件夹
//if($d->import_sql($d->data_dir)){
// echo '恢复成功';
//}その他{
// echo '恢复失败';
//}

www.bkjia.com本当http://www.bkjia.com/PHPjc/630845.html技術記事説明すると、この種類は小規模な Web サイトのデータベースに適しており、MYSQL 接続を内部に配置し、データ接続 * と保存場所を個別に設定するだけで十分です。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。