A-A+

php数据库备份源代码

2013年09月04日 PHP技术文章 评论 8 条 阅读 297 views 次

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"新建立目录";  
    		}
   		}

   		//判断文件是否存在
   		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: %s\n", 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].";\n\n";
  
         $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&#91;$i&#93;)."'";
                 $comma = ",";
              }
             $tabledump .= ");\n";
          }
         $tabledump .= "\n";
  
          return $tabledump;
      }
?>
标签:

8 条留言  访客:8 条  博主:0 条

  1. 吴郝斌

    php备份就像电脑需要备份一样,需要预防突然事件的发生。

  2. 音乐外链网

    这个好啊,以后自动备份,垃圾主机必备

  3. 北漂书生

    经常备份的是好同学,呵呵

  4. IT三两事

    很强大的功能,支持下

  5. 手工棉鞋批发

    以前我不懂,现在我懂了。看帖要回

  6. 李明

    不错,谢谢分享!

  7. 21氪

    这个是好东西,养成备份习惯最好

  8. nhzy资讯

    不错的网站,互访哦亲!

给我留言