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语 ...
随机推荐
- java基础之JDBC七:C3P0连接池的使用
使用C3P0的前提是需要引入jar包 具体使用如下: /** * c3p0的应用 * 前提:引入c3p0的jar包 */ public class Test { public static void ...
- 图论算法》关于SPFA和Dijkstra算法的两三事
本来我是想把这两个算法分开写描述的,但是SPFA其实就是Dijkstra的稀疏图优化,所以其实代码差不多,所以就放在一起写了. 因为SPFA是Dijkstra的优化,所以我想来讲讲Dijkstra. ...
- inux下安装ab
1,APR 下载地址:http://apr.apache.org/download.cgi 1)tar -zxf apr-1.4.5.tar.gz ./configure --prefix=/u ...
- ./run.sh --indir examples/demo/ --outdir examples/results/ --vis
(AlphaPose20180911) luo@luo-ThinkPad-W540:AlphaPose$ ./run.sh --indir examples/demo/ --outdir exampl ...
- 符合mvc思维的分页思想
.Model Student.cs namespace WebApplication14.Models { public class Student { public int Id { get; se ...
- 2.python IP/DNS地址处理之IPy/Dnspython模块
1.IPy模块 在IP地址规划中,涉及到计算大量的IP地址,包括网段.网络掩码.广播地址.子网数.IP类型等,即便是专业的网络人员也要进行繁琐的计算,而IPy模块提供了专门针对IPV4地址与IPV6 ...
- WEB测试和APP测试区别
Web测试和App测试从流程上来说,没有区别.都需要经历测试计划方案,用例设计,测试执行,缺陷管理,测试报告等相关活动.从技术上来说,WEB测试和APP测试其测试类型也基本相似,都需要进行功能测试.性 ...
- Windows Server 2003 asp网页不能访问的常见问题
1. [开始]--[程序]--[管理工具]--[Internet信息服务管理器],在服务器名下的“web服务扩展”的右窗口,单击active server pages -> 单击[允许].2. ...
- 洛谷P2420 让我们异或吧(树链剖分)
题目描述异或是一种神奇的运算,大部分人把它总结成不进位加法. 在生活中…xor运算也很常见.比如,对于一个问题的回答,是为1,否为0.那么: (A是否是男生 )xor( B是否是男生)=A和B是否能够 ...
- Hackfive 使用TextSwitcher和ImageSwitcher实现平滑过渡
1. 应用场景: 通过向左和向右的导航按钮浏览日期列表 在日期选择空间中改变日期 倒计时始终 新闻刚要 2.用到的知识点是: TextSwitcher和ImageSwitcher Te ...