好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

一个简单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"新建立目录";                 } //开源代码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高级应用的详细内容...

  阅读:56次