Heim > php教程 > php手册 > 利用php把mysql数据库备份导出成sql示例

利用php把mysql数据库备份导出成sql示例

WBOY
Freigeben: 2016-05-25 16:38:19
Original
1015 Leute haben es durchsucht

用php代码实现数据库备份可以使网站的管理变得非常便捷,我们可以直接进后台操作就能完成数据库的备份.

关键技术:

1. 首先要得到该数据库中有哪些表,所用函数 mysql_list_tables(),然后可以将获取的所有表名存到一个数组.

2. show create table 表名 可以获取表结构.

3. select * from 表名 取出所有记录,用循环拼接成 insert into... 语句.

导出成的sql语句效果,具体代码如下:

<?php  
	 header("Content-type:text/html;charset=utf-8"); 
	 
	 //配置信息 
	 
	 $cfg_dbhost = &#39;localhost&#39;; 
	 
	 $cfg_dbname = &#39;ftdm&#39;; 
	 
	 $cfg_dbuser = &#39;root&#39;; 
	 
	 $cfg_dbpwd = &#39;root&#39;; 
	 
	 $cfg_db_language = &#39;utf8&#39;; 
	 
	 $to_file_name = "ftdm.sql"; 
	 
	 // END 配置   
	 
	 //链接数据库 
	 
	 $link = mysql_connect($cfg_dbhost,$cfg_dbuser,$cfg_dbpwd); 
	 
	 mysql_select_db($cfg_dbname); 
	 
	 //选择编码 
	 
	 mysql_query("set names ".$cfg_db_language); 
	 
	 //数据库中有哪些表 
	 
	 $tables = mysql_list_tables($cfg_dbname); 
	 
	 //将这些表记录到一个数组 
	 
	 $tabList = array(); 
	 
	 while($row = mysql_fetch_row($tables)){ 
	 
	  $tabList[] = $row[0]; 
	 
	 } 
	 
	 
	 
	 echo "运行中,请耐心等待...<br/>"; 
	 
	 $info = "-- ----------------------------rn"; 
	 
	 $info .= "-- 日期:".date("Y-m-d H:i:s",time())."rn"; 
	 
	 $info .= "-- Power by 代潇瑞博客(http://www.phprm.com/read/34.html)rn"; 
	 
	 $info .= "-- 仅用于测试和学习,本程序不适合处理超大量数据rn"; 
	 
	 $info .= "-- ----------------------------rnrn"; 
	 
	 file_put_contents($to_file_name,$info,FILE_APPEND); 
	 
	 //将每个表的表结构导出到文件 
	 
	 foreach($tabList as $val){ 
	 
	  $sql = "show create table ".$val; 
	 
	  $res = mysql_query($sql,$link); 
	 
	  $row = mysql_fetch_array($res); 
	 
	  $info = "-- ----------------------------rn"; 
	 
	  $info .= "-- Table structure for `".$val."`rn"; 
	 
	  $info .= "-- ----------------------------rn"; 
	 
	  $info .= "DROP TABLE IF EXISTS `".$val."`;rn"; 
	 
	  $sqlStr = $info.$row[1].";rnrn"; 
	 
	  //追加到文件 
	 
	  file_put_contents($to_file_name,$sqlStr,FILE_APPEND); 
	 
	  //释放资源 
	 
	  mysql_free_result($res); 
	 
	 } 
	 
	 
	 
	 
	 //将每个表的数据导出到文件 
	 
	 foreach($tabList as $val){ 
	 
	  $sql = "select * from ".$val; 
	 
	  $res = mysql_query($sql,$link); 
	 
	  //如果表中没有数据,则继续下一张表 
	 
	  if(mysql_num_rows($res)<1) continue; 
	 
	  // 
	 
	  $info = "-- ----------------------------rn"; 
	 
	  $info .= "-- Records for `".$val."`rn"; 
	 
	  $info .= "-- ----------------------------rn"; 
	 
	  file_put_contents($to_file_name,$info,FILE_APPEND); 
	 
	  //读取数据 
	 
	  while($row = mysql_fetch_row($res)){ 
	 
	   $sqlStr = "INSERT INTO `".$val."` VALUES ("; 
	 
	   foreach($row as $zd){ 
	 
	    $sqlStr .= "&#39;".$zd."&#39;, "; 
	 
	   } 
	 
	   //去掉最后一个逗号和空格 
	 
	   $sqlStr = substr($sqlStr,0,strlen($sqlStr)-2); 
	 
	   $sqlStr .= ");rn"; 
	 
	   file_put_contents($to_file_name,$sqlStr,FILE_APPEND); 
	 
	  } 
	 
	  //释放资源 
	 
	  mysql_free_result($res); 
	 
	  file_put_contents($to_file_name,"rn",FILE_APPEND); 
	 
	 } 
	 
	 echo "OK!"; 
	 
	
Nach dem Login kopieren

本文地址:

转载随意,但请附上文章地址:-)

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage