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语 ...
随机推荐
- 03.WSDL分析
自己做一个程序放到tomcat里面这个就是服务,自己安装一个oracle,oracle启动之后那它本身就是一种服务. WebService就是HTTP,那么它和HTTP有什么不同呢? HTTP GET ...
- MySql 之 FIND_IN_SET 和IN
CREATE TABLE `test` ( `id` int(8) NOT NULL auto_increment, `name` varchar(255) NOT NULL, `list ...
- Suse系统磁盘文件损坏恢复
进入救援(failSafe)模式检测问题,发现是因为/dev/sda4分区出现文件系统损坏. /dev/sda4: UNEXPECTED INCONSISTENCY: run fsck manua ...
- 面试题:JVM类加载机制详解(一)JVM类加载过程 背1
首先Throws(抛出)几个自己学习过程中一直疑惑的问题: 1.什么是类加载?什么时候进行类加载? 2.什么是类初始化?什么时候进行类初始化? 3.什么时候会为变量分配内存? 4.什么时候会为变量赋默 ...
- Solidity payable 方法表现
pragma solidity ^; contract Person { string public name; uint age; uint private weight; string inter ...
- java类中final方法的作用
不给子类复写这个方法.说明你已经知道这个方法提供的功能已经满足你要求,不需要进行扩展,并且也不允许任何从此类继承的类来覆写这个方法,但是继承仍然可以继承这个方法,也就是说可以直接使用 inline扩展 ...
- 31.SUM() 函数
SUM() 函数 SUM 函数返回数值列的总数(总额). SQL SUM() 语法 SELECT SUM(column_name) FROM table_name SQL SUM() 实例 我们拥有下 ...
- Luogu 2704 [NOI2001]炮兵阵地
唔,想到了状压之后就不会了……实在是菜 考虑压两行,设$f_{i, j, k}$表示当前到第$i$行,上一行是$j$状态,前一行是$k$状态的最多能放的炮兵的数量. 发现第一维还可以滚掉,好像可以转移 ...
- Spring Boot 启动失败,描述/Description: Cannot determine embedded database driver class for database type NONE
异常截图====> 快速解决方式==> 在SpringBoot的启动类上面添加注解:@EnableAutoConfiguration(exclude={DataSourceAutoConf ...
- android和.net webservice中的DES加密算法
也是看了一堆的例子,本身并不会写加密算法,好在只要会用就行了,我们把在app中使用的参数加密,然后在.net端的webservice中进行解密,本身并没有什么问题,但是android下和.net下的d ...