一个简单php数据库备份程序
发布:smiling 来源: PHP粉丝网 添加日期:2014-09-10 13:12:46 浏览: 评论:0
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.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;
- }
- ?>
Tags: php数据库备份 mysql数据备份
相关文章
- ·php数据库备份类程序代码(2014-09-10)
- ·PHP实现MySQL数据库备份的源码(2018-10-30)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)