一个简单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"新建立目录"; } //开源代码phpfensi测试数据 } //判断文件是否存在 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 ; } ?>查看更多关于一个简单php数据库备份程序 - php高级应用的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did30498