1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務時間:8:30-17:00
      你可能遇到了下面的問題
      關閉右側工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      php自動備份數(shù)據(jù)庫,mysql數(shù)據(jù)庫備份數(shù)據(jù)

      php 代碼備份數(shù)據(jù)庫

      ?php

      公司主營業(yè)務:網(wǎng)站設計、網(wǎng)站建設、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出澧縣免費做網(wǎng)站回饋大家。

      /*

      **************function?db_bak()********************

      *??功能:備份指定的數(shù)據(jù)庫中的指定表

      *??輸入(按傳入?yún)?shù)解釋):$db_name?要備份的數(shù)據(jù)庫,$tb_array要備份的表,數(shù)組形式的,如果不是數(shù)組,將備份整個庫。

      $dir輸出備份文件的目錄,$filename備份文件名,$block_num指定分塊大小(指一條insert語句包含幾天數(shù)據(jù))

      *??輸出:備份的數(shù)據(jù)表的sql語句文件,可用于還原

      */

      function?db_bak($mylink,$dbname,$tab_array="",$dir,$filename,$block_num=20){

      mysql_select_db($dbname,$mylink)?or?db_error(mysql_error());

      is_array($tab_array)?or?$tab_array=db_showtb($mylink,$dbname,true);?//如果$tab_array不是數(shù)組,則取得整個庫的表

      if($dir){

      if(!file_exists($dir)){

      $flag=mkdir($dir);

      if(!$flag)

      return?2;

      }

      }

      //檢查數(shù)據(jù)表是否存在

      foreach($tab_array?as?$tab)

      db_e_tab($mylink,$dbname,$tab)?or?db_error($tab."?is?not?exist!");

      $fp=fopen($dir.$filename,"w");

      foreach($tab_array?as?$tab){??

      fputs($fp,"DROP?TABLE?IF?EXISTS?".$tab.";\r\n");

      $tabdef_array=mysql_fetch_array(mysql_query("SHOW?CREATE?TABLE?".$tab,$mylink));

      fputs($fp,str_replace("\n","",$tabdef_array["Create?Table"]).";\r\n");?

      fputs($fp,"LOCK?TABLES?".$tab."?WRITE;\r\n");?

      $getvalue_result=mysql_query("select?*?from?".$tab,$mylink);

      if(mysql_num_rows($getvalue_result)){

      $i=1;??

      $p="";

      $start_flag=true;

      while($getvalue_array=mysql_fetch_row($getvalue_result)){

      $values=join("','",array_map('db_data_check',$getvalue_array));

      $start_flag??fputs($fp,"insert?into?".$tab."?values");

      if($i$block_num){

      fputs($fp,",('".$values."');\r\n");

      $start_flag=true;

      $i=0;

      }else{

      fputs($fp,$p."('".$values."')");

      $start_flag=false;

      $i++;

      }

      $p=$start_flag?"":",";?

      }

      $start_flag?or?fputs($fp,";\r\n");

      }

      fputs($fp,"UNLOCK?TABLES;\r\n");??

      }

      fclose($fp);??

      }

      /*

      **************function?db_in()********************

      *??功能:還原備份函數(shù)db_bak生成的數(shù)據(jù)庫文件

      *??輸入(按傳入?yún)?shù)解釋):$db_name?要備份的數(shù)據(jù)庫,$filename要還原的數(shù)據(jù)庫文件

      *??輸出:將數(shù)據(jù)還原到數(shù)據(jù)庫

      *??原理:將文件分割成一個數(shù)組,然后逐條將數(shù)據(jù)導入數(shù)據(jù)庫

      *??警告:執(zhí)行該函數(shù)會刪除原來的數(shù)據(jù)表

      */

      function?db_in($mylink,$dbname,$filename){

      if(!file_exists($filename)){

      return?0;

      }

      db_e_db($mylink,$dbname)?or?(mysql_query("create?database?".$dbname,$mylink)or?db_error(mysql_error()));

      mysql_select_db($dbname,$mylink);

      $sql_array=file($filename);

      foreach($sql_array?as?$sql){

      mysql_query(trim($sql),$mylink)?or?db_error(mysql_error());

      }

      }

      ??

      //我自己寫的。可以參考哈

      如何使用PHP自動備份數(shù)據(jù)庫

      使用mysqldump函數(shù)

      mysqldump -u username -p dbname table1 table2 ... ? BackupName.sql

      dbname參數(shù)表示數(shù)據(jù)庫的名稱

      table1和table2參數(shù)表示需要備份的表的名稱,為空則整個數(shù)據(jù)庫備份;

      BackupName.sql參數(shù)表設計備份文件的名稱,文件名前面可以加上一個絕對路徑。通常將數(shù)據(jù)庫被分成一個后綴名為sql的文件。

      備份數(shù)據(jù)庫的主要過程:

      切換到對應的數(shù)據(jù)庫;

      使用show create table ?tableName,獲得表結構,寫到文件中;

      然后查詢所有的表數(shù)據(jù),循環(huán)生成相對應sql語句,寫到文件中;

      試運行生成的sql文件。

      如何用PHP來實現(xiàn) 備份 mysql 數(shù)據(jù)庫的 功能 ? 就是鼠標單擊 讓此項目的數(shù)據(jù)庫自動保存到相應的文件夾?

      我想到的有三種思路吧

      1.如果服務器允許mysqldump 并且沒有禁止PHP的shell_exec()這個函數(shù)的話

      直接在PHP里面執(zhí)行mysqldump就可以了。

      2.通過mysql_query('show tables')的返回值遍歷每個表,循環(huán)對每個表使用查詢語句

      select * into outfile '路徑/文件名' from 表名

      缺點是這樣得到的是純數(shù)據(jù),恢復數(shù)據(jù)的時候你需要額外再寫腳本

      3.同樣通過show tables返回表名,遍歷每個表,通過select 語句查詢,然后逐條結果處理,比如手工添加drop table 和create table 以及insert into等等,然后再寫入文件。這樣得到的備份數(shù)據(jù)是比較接近mysqldump的結果的,各種工具都可以用來恢復數(shù)據(jù)。缺點是如果數(shù)據(jù)庫太大的話,效率不好說

      總之我不推薦用PHP來實現(xiàn)mysql數(shù)據(jù)的備份,如果可能的話還是用mysqldump吧

      關于PHP+Mysql數(shù)據(jù)庫自動備份的問題

      先說代碼,我看了一下,代碼沒什么問題,至于你說的不備份,原因可能如下:

      查詢無結果,測試辦法是在最外層的那個while語句結束后輸出查詢語句,即:

      while?($t?=?mysql_fetch_array($q1))

      {

      //里面的代碼

      }

      echo?$mysql;//在這里輸出查詢結果,如果結果正常,則說明查詢有結果

      $filename?=?"autobackup.sql";?//存放路徑,默認存放到項目最外層

      然后就是另一個問題了,目標文件不可寫,你可以參考下面這樣的代碼

      $filename?=?"autobackup.sql";?//存放路徑,默認存放到項目最外層

      if(!file_exists($filename)?||?is_writable($filename))//如果文件不存在或可寫

      {

      $fp?=?fopen($filename,?'w');//打開或創(chuàng)建可寫文件

      $mysql=str_replace("','','');","',null,null);",$mysql);

      fputs($fp,?$mysql);//寫入

      fclose($fp);

      }

      else

      {

      echo?"文件?$filename?不存在或不可寫";

      }

      如果嘗試發(fā)現(xiàn)仍有問題,請再追問


      名稱欄目:php自動備份數(shù)據(jù)庫,mysql數(shù)據(jù)庫備份數(shù)據(jù)
      網(wǎng)站鏈接:http://www.ef60e0e.cn/article/dsejhpo.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        杭锦旗| 兴隆县| 道孚县| 绥德县| 永仁县| 敦化市| 清远市| 昭觉县| 建宁县| 乡宁县| 资阳市| 红河县| 当涂县| 徐闻县| 乌兰县| 凌海市| 临汾市| 容城县| 漳平市| 松桃| 徐水县| 和静县| 通城县| 济阳县| 崇左市| 泰安市| 江孜县| 福泉市| 永胜县| 青海省| 潼关县| 开远市| 长垣县| 建始县| 财经| 澳门| 略阳县| 景洪市| 杭锦旗| 凤山市| 罗源县|