A-A+
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"新建立目录"; } } //判断文件是否存在 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[$i])."'"; $comma = ","; } $tabledump .= ");\n"; } $tabledump .= "\n"; return $tabledump; } ?>
php备份就像电脑需要备份一样,需要预防突然事件的发生。
这个好啊,以后自动备份,垃圾主机必备
经常备份的是好同学,呵呵
很强大的功能,支持下
以前我不懂,现在我懂了。看帖要回
不错,谢谢分享!
这个是好东西,养成备份习惯最好
不错的网站,互访哦亲!