PHP 备份还原 MySql 数据库
备份还原数据库
重构代码,文件名不再支持中文名,中文可能乱码或压缩文件失败
数据库使用 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); // 修复表
演示示例


PHP 备份还原 MySql 数据库的更多相关文章
- 备份还原mysql数据库
Windows下cmd命令行中备份还原mysql数据库 先cmd 上cd 到mysql的安装bin目录下,然后再运行下面的命令. 例如:cd C:\Program Files\MySQL\MySQL ...
- C#备份还原MySql数据库
原文:C#备份还原MySql数据库 项目结束,粘点代码出来让Google或Baidu一下,原因是现在还搜不到这么现成的 调用MySql的工具mysqldump来实现. 类Cmd来实现调用cmd命令, ...
- xtrabackup备份还原MySQL数据库
mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况Xtrabackup可以解决mysqldump存在的上述的 ...
- Navicat工具备份还原mysql数据库详细图解
Navicat是个很不错的MYSQL数据库管理工具,我们常用的还web形式的phpmyadmin和font这三种了,都是非常不错的mysql管理工具.因为Navicat工具兼容性比较好,操作也比较简单 ...
- 高速备份还原MYSQL数据库
#安装依赖包yum -y update gccyum -y install gcc+ gcc-c++ #安装cd /usr/local/softwaretar -jxvf p7zip_16.02_sr ...
- php程序备份还原mysql数据库
<?php $link = mysql_connect("localhost", "root",""); mysql_query(&q ...
- 备份/还原MySQL数据库----MySQL Workbench
点击[Data Export],界面右侧将显示数据导出窗口. 2 点击[Refresh]按钮,刷新数据库列表(1),选择要导出的数据表(2),设置导出的目录(3),点击[Start Export]按钮 ...
- 备份/还原mysql数据库
有木有遇到过这种情况?电脑或者服务器需要重装系统?可是你电脑上存着n多个网站的数据库,怎么办?把数据库文件夹拷贝出来,重装系统之后再拷回去?如果你使用了InnoDB引擎,恐怕那样做会出麻烦的,一个一个 ...
- Java在线备份和还原MySQL数据库。
2018年6月29日14:00:48 阅读数:1534 今天整了整整一整天,终于使用Java在线备份和还原MySQL数据库了,哎,备份倒是很快,就是在还原的时候遇到了一个问题,也不报错,结果将sql语 ...
随机推荐
- Apache与Tomcat联系及区别
Apache与Tomcat都是Apache开源组织开发的用于处理HTTP服务的项目,两者都是免费的,都可以做为独立的Web服务器运行.Apache是Web服务器而Tomcat是Java应用服务器. A ...
- Zookeeper Api(java)入门与应用
如何使用 Zookeeper 作为一个分布式的服务框架,主要用来解决分布式集群中应用系统的一致性问题,它能提供基于类似于文件系统的目录节点树方式的数据存储,但是 Zookeeper 并不是用来专门存储 ...
- zend studio 字体大小修改,默认编码设置
zend studio的字体感觉很小,很多用户不是很适应,修改方法如下: 第一步:进入设置窗口 windows -> preferences 第二步:进入修改字体的选项卡. Gene ...
- SpringBoot22 Ajax跨域、SpringBoot返回JSONP、CSRF、CORS
1 扫盲知识 1.1 Ajax为什么存在跨域问题 因为浏览器处于安全性的考虑不允许JS执行跨域请求. 1.2 浏览器为什么要限制JS的跨域访问 如果浏览器允许JS的跨域请求就很容易造成 CSRF (C ...
- 189. Rotate Array 从右边开始翻转数组
[抄题]: Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, the ...
- Newtonsoft 序列化和反序列化特殊处理
1>序列化,时间格式化处理 JsonConvert.SerializeObject(Iar, new JsonSerializerSettings() { DateFormatString = ...
- jQuery--加一行减一行
效果: 知识点: 克隆--clone() 追加--append() 移除--remove() 代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 2 ...
- CLR VIA C# 泛型的协变和逆变
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- File类中的list()和listFiles()方法
list()方法是返回某个目录下的所有文件和目录的文件名,返回的是String数组 listFiles()方法是返回某个目录下所有文件和目录的绝对路径,返回的是File数组 public class ...
- 关于VBS的一个怪现象
今天一个同学让我帮忙写一个程序,要求是: 输入一个n,返回从0到n中任意个数的组合,返回取异或结果为0的组合.来看VBS代码 n = p = "" ^n - s = s = s ) ...