首页 > php开发 > 一个简单php数据库备份程序

一个简单php数据库备份程序

php备份mysql数据库是很多个人站长网站所具备的功能,当然如果你要备份几个GB或更大的数据库时php备份方法感觉有点吃力了.

PHP 备份 mysql 数据库的源代码,在完善的 PHP+Mysql 项目中,在后台都会有备份 Mysql 数据库的功能,有了这个功能,我们就不用再使用 FTP 或者使用 mysql 的管理工具进行 mysql 数据库下载了,非常方便,对于想做这样功能的 phper 来说,其实原理并不是很麻烦,主要有以下三点.

一,一定要连接数据库,这样才能通过 SQL 语句打印出 mysql 数据表.

二,通过 PHP 的文件操作函数进行数据库的操作,包括创建保存 mysql 数据库的文件夹,这一步主要就是新建文件的步骤.

三,将 mysql 数据库进行保存下来.

通过这样的原理,我们就可以制作出一个属于自己的备份数据库的功能了,下面是一个php数据库备份的源代码,主要结构是依据上面的三点进行的,源码是由几个方法组成的,我们也可以将其封装成为自己的 php 类,举一反三,希望 phper 能在此基础上设计出适合自己的 mysql 数据库备份功能源码,代码如下:

<?php 
	/** 备份数据库 生成.sql文件 
	     * @param $browseinfo  String  浏览器版本 
	     * return $browseinfo 
	     */ 
	    function createsql(){ 
	        //创建个日期 
	        $timer1 = time(); 
	        $path = "my_sql/"; 
	        $content =gettables(); 
	        $filename = $path.$timer1.".sql"; 
	    
	        //先判断文件夹在不在 
	         if(!file_exists($path)){ 
	        //如果不存在生成这个目录,0777表示最大的读写权限 
	            if(mkdir($path,0777)){ 
	            //echo"新建立目录";   
	            }//开源代码phprm.com 
	        } 
	 
	        //判断文件是否存在 
	        if(!file_exists($filename)){ 
	            //如果文件不存在,则创建文件 
	            @fopen($filename,"w"); 
	 
	            //判断文件是否可写 
	            if(is_writable($filename)){ 
	            //打开文件以添加方式即"a"方式打开文件流 
	                if(!$handle =  fopen($filename,"a")){ 
	                    echo"文件不可打开"; 
	                    exit(); 
	                } 
	 
	            if(!fwrite($handle,$content)){ 
	                echo"文件不可写"; 
	                exit(); 
	            } 
	 
	        //关闭文件流 
	        fclose($handle); 
	        echo "生成文件并保存首次内容"; 
	         
	    }else { 
	        echo"文件$filename不可写"; 
	    } 
	        }else{ 
	            if(is_writable($filename)){ 
	            //以添加方式打开文件流 
	            if(!$handle = fopen($filename,"a")){ 
	                echo"文件不可打开"; 
	                exit(); 
	            } 
	            fclose($handle); 
	            }else{ 
	                echo "文件$filename不可写"; 
	            } 
	    } 
	} 
	 
	 
	    /** 
	     * 获得数据库中的表名 
	     * return $str 循环生成数据库建表和插入值的sql语句 
	     */ 
	    function gettables(){ 
	        $mysqli = new mysqli("localhost","root","","bbs"); 
	        $str = ''; 
	        if ($result = $mysqli->query("SHOW TABLES")) { 
	            while($row = $result->fetch_row()){ 
	                $str.= data2sql($row[0])."<br/>"; 
	            } 
	            $mysqli->close(); 
	            return $str; 
	        }    
	     
	    }  
	    
	 
	    /** 
	     * 获得数据库中的表结构和值 
	     * return $tabledump 返回一个表中的结构和值的sql语句 
	     */ 
	    function data2sql($table){   
	     $mysqli = new mysqli("localhost","root","","bbs"); 
	        /* check connection */ 
	        if (mysqli_connect_errno()) { 
	            printf("Connect failed: %sn", mysqli_connect_error()); 
	        exit(); 
	    } 
	         $tabledump = "DROP TABLE IF EXISTS $table;n"; 
	         $result = $mysqli->query("SHOW CREATE TABLE $table"); 
	         $create = $result->fetch_row();  
	         $tabledump .= $create[1].";nn"; 
	   
	         $rows = $mysqli->query("SELECT * FROM $table"); 
	         $numfields = $rows->num_rows; 
	 
	            while ($row = $rows->fetch_row()){ 
	             $comma = ""; 
	             $tabledump .= "INSERT INTO $table VALUES("; 
	              for($i = 0; $i < $numfields; $i++) 
	              { 
	                 $tabledump .= $comma."'".mysql_escape_strin 
	g($row[$i])."'"; 
	                 $comma = ","; 
	              } 
	             $tabledump .= ");n"; 
	          } 
	         $tabledump .= "n"; 
	   
	          return $tabledump; 
	      } 
	

教程地址:http://www.phprm.com/develop/fs5239.html

欢迎转载!但请带上文章地址^^

标签:mysql数据备份 php数据库备份

发表留言