PHP备份数据库为SQL文件 并可下载源码

  这是一个将指定数据库里的所有表备份为一个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.     
  60. <!--?php         
  61. $host="localhost"; //主机名         
  62. $user="root"; //MYSQL用户名         
  63. $password="root"; //密码         
  64. $dbname="dedecmsv4"; //备份的数据库         
  65.        
  66. mysql_connect($host,$user,$password);         
  67. mysql_select_db($dbname);         
  68.        
  69. $q1=mysql_query("show tables");         
  70. while($t=mysql_fetch_array($q1)){         
  71. $table=$t[0];         
  72. $q2=mysql_query("show create table `$table`");         
  73. $sql=mysql_fetch_array($q2);         
  74. $mysql.=$sql['Create Table'].";\r\n\r\n";#DDL         
  75.        
  76. $q3=mysql_query("select * from `$table`");         
  77. while($data=mysql_fetch_assoc($q3))         
  78. {         
  79. $keys=array_keys($data);         
  80. $keys=array_map('addslashes',$keys);         
  81. $keys=join('`,`',$keys);         
  82. $keys="`".$keys."`";         
  83. $vals=array_values($data);         
  84. $vals=array_map('addslashes',$vals);         
  85. $vals=join("','",$vals);         
  86. $vals="'".$vals."'";         
  87.        
  88. $mysql.="insert into `$table`($keys) values($vals);\r\n";         
  89. }         
  90. $mysql.="\r\n";         
  91.        
  92. }         
  93. $filename=date('Ymd')."_".$dbname.".sql"; //文件名为当天的日期         
  94. $fp = fopen($filename,'w');         
  95. fputs($fp,$mysql);         
  96. fclose($fp);         
  97. echo "数据备份成功,生成备份文件".$filename;         
  98. ?>   

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据库
, 结构
, 函数
, table
, 备份
, createtable
, 可下载
迅雷可下载
c 数据库备份源代码、php网站源码带数据库、php数据库管理源码、php搜索数据库源码、php导入数据库源码,以便于您获取更多的相关知识。

时间: 2024-09-08 16:56:00

PHP备份数据库为SQL文件 并可下载源码的相关文章

PHP备份数据库生成SQL文件并下载的函数代码_php技巧

复制代码 代码如下: <!?php /****** 备份数据库结构 ******/ /* 函数名称:table2sql() 函数功能:把表的结构转换成为SQL 函数参数:$table: 要进行提取的表名 返 回 值:返回提取后的结果,SQL集合 函数作者:heiyeluren */ function table2sql($table) { global $db; $tabledump = "DROP TABLE IF EXISTS $table;n"; $createtable

Java实现把excel xls中数据转为可直接插入数据库的sql文件_java

我的一贯风格,代码说明一切.. 废话不多说了,直接给大家贴代码了,具体代码如下所示: package Tools; import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.lang.reflect.Field; import java.util.ArrayList; import java.util.List; im

求教如何java程序调用cmd 连接mysql数据库读取sql文件

问题描述 求教如何java程序调用cmd 连接mysql数据库读取sql文件 开始 -> 运行 -> 输入CMD D: cd mysqlbin mysql -u root -p123456 test <d:a.sql 这是在命令行执行的 谁能告诉我JAVA要怎么写 谢谢啦 解决方案 http://www.cnblogs.com/taoweiji/archive/2012/12/11/2812852.html 解决方案二: java本身就是在虚拟机里面运行的,不可能去调用Windows的组

linux 备份数据库与网站文件详解

例1,手动备份数据库与网站文件  代码如下 复制代码 #!/bin/sh # 文 件 名: rptsmain.sh # 版    权: Copyright (shell) 2007-2007  # 版 本 号: V1.0 # 功能描述:  数据备份 # 创 建 人: xxxxx # 日    期: 2007/10/26 # 修 改 人:xxxxxxx # 日    期: 2007/10/26 #程序开始 TODAY=`date "+%Y%m%d"` WORKDATE=$TODAY BA

构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码]

原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码] 文件上传这东西说到底有时候很痛,原来的asp.net服务器控件提供了很简单的上传,但是有回传,还没有进度条提示.这次我们演示利用swfupload多文件上传,项目上文件上传是比不可少的,大家这个心里都知道.主要提供给源码说明及下载 最终效果图: SWFUpload的特点: 1.用flash进行上传,页面无刷新,且可自定义Flash按钮的样式; 2.可以在浏

Python 基于Twisted框架的文件夹网络传输源码_python

由于文件夹可能有多层目录,因此需要对其进行递归遍历. 本文采取了简单的协议定制,定义了五条命令,指令Head如下: Sync:标识开始同步文件夹 End:标识结束同步 File:标识传输的文件名(相对路径) Folder:标志文件夹(相对路径) None:文件内容 每条命令以CMB_BEGIN开始,以CMB_END结束. 客户端需要对接收缓冲做解析,取出一条一条的指令,然后根据指令的Head做相应的处理,比如创建文件夹.写入文件等. 下面是服务端的代码: from twisted.interne

使用MYSQL界定符备份及还原数据库 比sql文件更给力

在<高性能Mysql>第二版中看到,SQL文件和界定符文件在备份.还原时的耗费时间对比. 方式 文件大小 导出时间 还原时间 SQL dump 727M 102s 600s Delimited dump 669M 86s 301s 看起来界定符文件的导出比sql文件快了近20%,还原速度快了一倍. 记录和总结一下语法: 备份:SELECT INTO OUTFILE SELECT * FROM hx_9enjoy INTO OUTFILE '/tmp/9enjoy.txt' 默认使用tab分割字

解析MYSQL 数据库导入SQL 文件出现乱码的问题

导入数据时,如果目标数据库或表是UTF-8字符集的,而导入SQL中有中文,可能在最终结果中出现乱码,此时只需在导入的SQL文件第一行加入如下内容 即可. /*!40101 SET NAMES utf8 */;

解析MYSQL 数据库导入SQL 文件出现乱码的问题_Mysql

导入数据时,如果目标数据库或表是UTF-8字符集的,而导入SQL中有中文,可能在最终结果中出现乱码,此时只需在导入的SQL文件第一行加入如下内容 即可./*!40101 SET NAMES utf8 */;