备份还原数据库

重构代码,文件名不再支持中文名,中文可能乱码或压缩文件失败
数据库使用 PDO 连接,不再支持 MySql 连接
备份文件名定义 Backup 类中 $this->dir_file_name 属性定义,默认使用 年月日时(2019081719)
备份文件目录 Common 类中 $this->config['back_dir']属性定义
公共配置项 Common 类中 $this->config 备份文件配置项 Backup 类中 $this->back_config
还原文件配置项 Import 类中 $this->import_config

版本
测试PHP版本7.0.12,其他版本未测试; 建议PHP版本5.5以上

项目文件目录

src
|--- backup/ 备份还原文件夹
|--- Backup.php 备份数据库类文件
|--- Common.php 备份、还原、修复表、优化表基类
|--- Db.php 封装 sql 语句
|--- DbData.php 数据库数据操作
|--- demo.php 示例演示文件
|--- Import.php 还原数据库类文件
|--- OptimizeRepair.php 优化修复表类文件

配置项

$config=[
// 数据库配置
'db' => 'web', // 数据库名称 必传
'host'=> '127.0.0.1', // 主机 必传
'dbuser'=>'root', // 数据库用户名称 必传
'dbpw'=> 'root', // 数据库密码 必传
'charset' =>'utf8', // 字符集
'timezone'=>'PRC', // 时区
'prot' => 3306, // mysql 数据库端口号
// 可以添加自定义配置项
// 公共配置项
'file_delimiter' => '_', // 分卷分割符,如果修改其他符号,文件名匹配正则需要修改
'file_extension' => "sql", // 备份文件后缀名
'compress_file_extension' => 'zip',// 压缩文件后缀
'import_lock_file' => 'import_lock_file.txt',// 导入锁文件名
'backup_lock_file' => 'backup_lock_file.txt',//备份锁文件
'back_dir' => './backup/', // 备份文件路径,备份
// 备份配置项
'subsection' => 5, // 分卷大小,单位MB
'min_subsection' => 2, // 最小分卷数
'max_subsection' => 50, // 最大分卷数
'compress' => false, // 是否压缩,默认不压缩
'data_limit' => 10, // 表数据每10 条统计一次是否达到分卷字数,如果为0表数据中不判断
'charset' => 'utf8', // 字符集
// 还原配置项
'del_file' =>false, // 还原完数据库是否删除文件夹以及文件夹中所有文件,默认不删除
'read_size'=>8192 // 一次读取文件字节个数
];

备份数据库

默认分卷大小 5MB
分卷计算默认是10 条数据统计一次分卷大小,如果设置为 0 ,表数据中不统计分卷大小,每卷可能会超出设置的分卷大小
参数说明:

$config 数据库配置信息
$table 要备份的表名,备份整个数据库 null,备份指定前缀的数据表(参数是字符串),备份指定表名的数据表(参数数组形式)

调用示例:

$exec_sql=new Backup($config);
$table=[];
$exec_sql->wirteFile($table);`

还原数据库

默认一次读取文件字节个数 8KB

  • 还原数据文件路径,还原文件名与路径相同
  • 例如还原文件路径是 ./backup/20190811015/
  • 配置文件所在路径 config['back_dir']='./backup/',readFile('20190811015'),参数是需要还原的文件夹名称
  • 还原文件会自动查找下类文件:
  • ./backup/20190811015/20190811015_0.sql
  • ./backup/20190811015/20190811015_1.sql
  • ./backup/20190811015/20190811015.zip
  • 如果既有压缩文件也有sql文件,只会还原20190811015/20190811015_0.sql 20190811015/20190811015_1.sql
  • 压缩文件20190811015/20190811015.zip不会执行还原操作
  • 如果需要还原(导入)额外数据表,在./backup/20190811015/ 文件夹下放 20190811015_1.zip ,20190811015_2.zip压缩包即可,压缩包文件名一致,下标从1 开始;
  • 压缩包里面的文件与文件名一致,例如:20190811015_1.zip 压缩包文件有 20190811015_0.sql 20190811015_1.sql,下标从0 开始

参数说明:

 $config 数据库配置项
$file_dir 还原文件夹名称

调用示例:

$file_dir='2019081719'
$import_sql=new Import($config);
$import_sql->readFile('2019081719');

优化修复表

参数说明:

$config 数据库配置项
$table 要操作的表名,操作整个数据库 null,操作指定前缀的数据表(参数是字符串),操作指定表名的数据表(参数数组形式)

调用示例:

$optimize_repair=new OptimizeRepair($config);
$table=[];
$optimize_repair->optimize($table); // 优化表
$optimize_repair->repair($table); // 修复表

演示示例

项目地址:https://github.com/xue-y/backrestore

packagist:https://packagist.org/packages/xue-y/backrestore

PHP 备份还原 MySql 数据库的更多相关文章

  1. 备份还原mysql数据库

    Windows下cmd命令行中备份还原mysql数据库 先cmd 上cd  到mysql的安装bin目录下,然后再运行下面的命令. 例如:cd C:\Program Files\MySQL\MySQL ...

  2. C#备份还原MySql数据库

    原文:C#备份还原MySql数据库 项目结束,粘点代码出来让Google或Baidu一下,原因是现在还搜不到这么现成的 调用MySql的工具mysqldump来实现. 类Cmd来实现调用cmd命令, ...

  3. xtrabackup备份还原MySQL数据库

    mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况Xtrabackup可以解决mysqldump存在的上述的 ...

  4. Navicat工具备份还原mysql数据库详细图解

    Navicat是个很不错的MYSQL数据库管理工具,我们常用的还web形式的phpmyadmin和font这三种了,都是非常不错的mysql管理工具.因为Navicat工具兼容性比较好,操作也比较简单 ...

  5. 高速备份还原MYSQL数据库

    #安装依赖包yum -y update gccyum -y install gcc+ gcc-c++ #安装cd /usr/local/softwaretar -jxvf p7zip_16.02_sr ...

  6. php程序备份还原mysql数据库

    <?php $link = mysql_connect("localhost", "root",""); mysql_query(&q ...

  7. 备份/还原MySQL数据库----MySQL Workbench

    点击[Data Export],界面右侧将显示数据导出窗口. 2 点击[Refresh]按钮,刷新数据库列表(1),选择要导出的数据表(2),设置导出的目录(3),点击[Start Export]按钮 ...

  8. 备份/还原mysql数据库

    有木有遇到过这种情况?电脑或者服务器需要重装系统?可是你电脑上存着n多个网站的数据库,怎么办?把数据库文件夹拷贝出来,重装系统之后再拷回去?如果你使用了InnoDB引擎,恐怕那样做会出麻烦的,一个一个 ...

  9. Java在线备份和还原MySQL数据库。

    2018年6月29日14:00:48 阅读数:1534 今天整了整整一整天,终于使用Java在线备份和还原MySQL数据库了,哎,备份倒是很快,就是在还原的时候遇到了一个问题,也不报错,结果将sql语 ...

随机推荐

  1. XHProf安装使用笔记

    编译安装 获取源代码包root@sourcjoy>wget http://pecl.php.net/get/xhprof-0.9.2.tgz解压root@sourcjoy>tar zxf ...

  2. SpringBoot26 利用 Ribbon + RestTemplate 调用远程服务资源

    1 RestTemplate扫盲 借助 RestTemplate,Spring应用能够方便地使用REST资源  2 准备 创建三个springCloud项目 >Eureaka : 服务注册中心 ...

  3. 面试题:Java集合面试题(40道) 背1

    Java集合框架为Java编程语言的基础,也是Java面试中很重要的一个知识点.这里,我列出了一些关于Java集合的重要问题和答案. 1.Java集合框架是什么?说出一些集合框架的优点? 每种编程语言 ...

  4. c语言实践 打印数字三角形

    效果如下图: 思路就是外层循环控制要打印的行数,里层循环控制每行打印的数字个数. int val = 65; for (int i = 0; i < 6; i++) { for (int j = ...

  5. Linux pkg-config命令

    一.简介 pkg-config用来检索系统中安装库文件的信息.典型的是用作库的编译和连接. 二.实例 http://blog.chinaunix.net/uid-20595934-id-1918368 ...

  6. Smarty3——复合变量修饰器输

    你可以联合使用多个修饰器. 它们会按复合的顺序来作用于变量,从左到右. 它们必须以| (竖线)进行分隔,以‘:’号设置参数 {$articleTitle} {$articleTitle|upper|s ...

  7. Flask 之 上下文管理

    Flask上下文管理 分类: 请求上下文管理 应用上下文管理 请求上下文管理 request a. 温大爷:wsig b. 赵毅: ctx = ReuqestContext(session,reque ...

  8. C#中特殊的string类型

                                                                                  string C#有string关键字,在翻 ...

  9. c++基础之引用reference

    1.何为引用 简单来说就是,比如你换了个新名字,用新名字叫你,你也会答应 2.引用vs指针 -引用没有null,好比你说你换了个新名字,但是新名字是啥总得有点东西 -一旦引用被初始化后就不可以指到另外 ...

  10. delphi将图片转换成Base64编码函数

    {************************************************************************** 名称: BaseImage 参数: fn: TF ...