首页 > php教程 > php手册 > 正文

PHP Mysql数据库备份类程序总结

php中文网
发布: 2016-05-25 16:37:53
原创
1441人浏览过

数据库备份类我们只要在网上一搜索在n多的类代码,下面我来总结几款不错数据库备份希望对大家有所帮助.

数据库备份类,使用方法,代码如下:

require_once("backdata.class.php"); 
$link = @mysql_connect("localhost","数据库名","密码") or die ('Could not connect to server.'); 
mysql_query("use cms",$link); 
mysql_query("set names utf8",$link);
$dbbck = new backupData($link);//实例化它,只要一个链接标识就行了 
 
//备份数据时,如想备份一个数据库中的所有表,你可这样写: 
$dbbck->backupTables("cms","./",array('*')); 
 
//备份数据时,如想备份一个数据库中的仅一个表时,你可这样写: 
$dbbck->backupTables("cms","./",array('user')); 
 
//备份数据时,如想备份一个数据库中的多个表时,你可这样写: 
$dbbck->backupTables("cms","./",array('user','acl','informatoin')); 
 
//注解:$dbbck->backupTables("参1","参2",array());中,
登录后复制

参1为:数据库名

参2为:要存放备份数据的位置(即目录地址)

第三个为:你要保存那些表

立即学习PHP免费学习笔记(深入)”;

PHP高级开发技巧与范例
PHP高级开发技巧与范例

PHP是一种功能强大的网络程序设计语言,而且易学易用,移植性和可扩展性也都非常优秀,本书将为读者详细介绍PHP编程。 全书分为预备篇、开始篇和加速篇三大部分,共9章。预备篇主要介绍一些学习PHP语言的预备知识以及PHP运行平台的架设;开始篇则较为详细地向读者介绍PKP语言的基本语法和常用函数,以及用PHP如何对MySQL数据库进行操作;加速篇则通过对典型实例的介绍来使读者全面掌握PHP。 本书

PHP高级开发技巧与范例 472
查看详情 PHP高级开发技巧与范例

backdata.class.php,代码如下:

<?php 
/* 
* 
*一个简单的Mysql备份数据类 
* 
*/ 
class backupData{ 
    private    $mysql_link;//链接标识 
    private    $dbName;    //数据库名 
    private    $dataDir;     //数据所要存放的目录 
    private    $tableNames;//表名 
 
    public function __construct($mysql_link){ 
         $this->mysql_link = $mysql_link; 
    } 
    public function backupTables($dbName,$dataDir,$tableNames){//开始备份 
        $this->dbName  = $dbName; 
        $this->dataDir  = $dataDir; 
        $this->tableNames = $tableNames; 
        $tables=$this->delarray($this->tableNames); 
        $sqls=''; 
        foreach($tables as $tablename){ 
            if($tablename==''){//表不存在时 
                continue; 
            } 
             
            //************************以下是形成SQL的前半部分************** 
            //如果存在表,就先删除 
            $sqls .= "DROP TABLE IF EXISTS $tablename;n"; 
            //读取表结构 
            $rs = mysql_query("SHOW CREATE TABLE $tablename",$this->mysql_link);   
            $row=mysql_fetch_row($rs); 
            //获得表结构组成SQL 
            $sqls.=$row['1'].";nn"; 
            unset($rs); 
            unset($row); 
             
            //************************以下是形成SQL的后半部分************** 
            //查寻出表中的所有数据 
            $rs=mysql_query("select * from $tablename",$this->mysql_link); 
            //表的字段个数 
            $field=mysql_num_fields($rs); 
            //形成此种SQL语句:"INSERT INTO `groups` VALUES('1499e0ca25988d','主任','','0');" 
            while($rows=mysql_fetch_row($rs)){ 
                $comma='';//逗号 
                $sqls.="INSERT INTO `$tablename` VALUES("; 
                for($i=0;$i<$field;$i++){ 
                    $sqls.=$comma."'".$rows[$i]."'"; 
                    $comma=','; 
                } 
                $sqls.=");nnn"; 
            } 
        } 
        $backfilepath=$this->dataDir.date("Ymdhis",time()).'.sql'; 
         
        //写入文件 
        $filehandle = fopen($backfilepath, "w"); 
        fwrite($filehandle, $sqls); 
        fclose($filehandle); 
    } 
    private function delarray($array){    //处理传入进来的数组 
        foreach($array as $tables){ 
            if($tables=='*'){    //所有的表(获得表名时不能按常规方式来组成一个数组) 
                $newtables=mysql_list_tables($this->dbName,$this->mysql_link); 
                $tableList = array(); 
                for ($i = 0; $i < mysql_numrows($newtables); $i++){ 
                    array_push($tableList,mysql_tablename($newtables, $i)); 
                } 
                $tableList=$tableList; 
            }else{ 
                $tableList=$array; 
                break; 
            } 
        } 
        return $tableList; 
    } 
}
登录后复制


本文地址:

转载随意,但请附上文章地址:-)

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号