登录模块加载中...
会员投稿 投稿指南 今天是:
打印本页 | 关闭窗口 | 双击滚屏 您的位置首页>>网页制作学习园地>>PHP教程>>php数据库相关>>PHP备份数据库为SQL文件的代码
PHP备份数据库为SQL文件的代码
来源:建站学 ‖ 作者:佚名 ‖ 点击: ‖ 时间:10-12-20 10:50:07 ‖ 【 】‖ 我要投稿
这是一个将指定数据库里的所有表备份为一个SQL文件,可下载。这个源码来自dedecms程序,功能挺多,也很实用,但是代码的质量还有待提高
  1. php    
  2.     
  3. /******   备份数据库结构 ******/    
  4.       
  5.       /*   
  6.       函数名称:table2sql()   
  7.       函数功能:把表的结构转换成为SQL   
  8.       函数参数:$table: 要进行提取的表名   
  9.       返 回 值:返回提取后的结果,SQL集合   
  10.       函数作者:heiyeluren   
  11.       */    
  12.       
  13.      function table2sql($table)    
  14.       {    
  15.           global $db;    
  16.          $tabledump = "DROP TABLE IF EXISTS $table;\n";    
  17.          $createtable = $db--->query("SHOW CREATE TABLE $table");    
  18.          $create = $db->fetch_row($createtable);    
  19.          $tabledump .= $create[1].";\n\n";    
  20.           return $tabledump;    
  21.       }    
  22.       
  23.       
  24.      /****** 备份数据库结构和所有数据 ******/    
  25.       /*   
  26.       函数名称:data2sql()   
  27.       函数功能:把表的结构和数据转换成为SQL   
  28.       函数参数:$table: 要进行提取的表名   
  29.       返 回 值:返回提取后的结果,SQL集合   
  30.       函数作者:heiyeluren   
  31.       */    
  32.      function data2sql($table)    
  33.       {    
  34.           global $db;    
  35.          $tabledump = "DROP TABLE IF EXISTS $table;\n";    
  36.          $createtable = $db->query("SHOW CREATE TABLE $table");    
  37.          $create = $db->fetch_row($createtable);    
  38.          $tabledump .= $create[1].";\n\n";    
  39.       
  40.          $rows = $db->query("SELECT * FROM $table");    
  41.          $numfields = $db->num_fields($rows);    
  42.          $numrows = $db->num_rows($rows);    
  43.           while ($row = $db->fetch_row($rows))    
  44.           {    
  45.              $comma = "";    
  46.              $tabledump .= "INSERT INTO $table VALUES(";    
  47.               for($i = 0; $i < $numfields$i++)    
  48.               {    
  49.                  $tabledump .= $comma."'".mysql_escape_string($row[$i])."'";    
  50.                  $comma = ",";    
  51.               }    
  52.              $tabledump .= ");\n";    
  53.           }    
  54.          $tabledump .= "\n";    
  55.       
  56.           return $tabledump;    
  57.       }    
  58. ?>    
  59.