public function exportDatabase(){
$data = input();
//备份数据库
$host="192.168.0.123";
$user="root";//数据库账号
$password="root";//数据库密码
$dbname="emblog";//数据库名称
//这里的账号、密码、名称都是从页面传过来的
if(@!mysql_connect($host,$user,$password)) //连接mysql数据库
{
echo '数据库连接失败,请核对后再试';
exit;
}
if(!mysql_select_db($dbname)) //是否存在该数据库
{
echo '不存在数据库:'.$dbname.',请核对后再试';
exit;
}
mysql_query("set names 'utf8'");
$mysql= "set charset utf8;\r\n";
///若要备份数据库里全部的数据表///选用//
// $q1=mysql_query("show tables"); //显示表名
// while($t=mysql_fetch_array($q1)){
// $table=$t[0];
/若要根据数据表名来备份数据///选用
foreach($input['table_box'] as $value){
$table=$value;
/
// DROP TABLE IF EXISTS `article`;
$q2=mysql_query("show create table `$table`");
$sql=mysql_fetch_array($q2);
$mysql.="DROP TABLE IF EXISTS `".$sql['Table']."`;\r\n".$sql['Create Table'].";\r\n";
$q3=mysql_query("select * from `$table`");
while($data=mysql_fetch_assoc($q3)){ //mysql_fetch_assoc()函数从结果集中取得一行作为关联数组。
$keys=array_keys($data);
$keys=array_map('addslashes',$keys);
$keys=join('`,`',$keys);
$keys="`".$keys."`";
$vals=array_values($data);
$vals=array_map('addslashes',$vals);
$vals=join("','",$vals);
$vals="'".$vals."'";
$mysql.="insert into `$table`($keys) values($vals);\r\n";
}
}
// dump($table.$keys);die; // 这里就已经获取到了所有的表以及内容
if (!file_exists('static/admin/data')){
@mkdir('static/admin/data');
}
$filename="data/".$dbname.date('YmdHis').".sql"; //存放路径,默认存放到项目最外层
$fp = fopen($filename,'w'); //fopen() 函数打开文件或者 URL。
fputs($fp,$mysql); //fputs() 函数写入文件(可安全用于二进制文件)
fclose($fp); //fclose() 函数关闭一个打开文件。
echo "<script>alert('备份成功');location.href='index'</script>";
}

这里的数据恢复需要和上面的数据备份配套
这里的数据还原需要传文件名以及文件路径
//数据恢复
public function inputDatabase($name){
$filename = $name;
$host="localhost"; //主机名
$user="root"; //MYSQL用户名
$password="root"; //密码
$dbname="emblog"; //在此指定您要恢复的数据库名,不存在则必须先创建,请自已修改数据库名
mysql_connect($host,$user,$password);
mysql_select_db($dbname);
$mysql_file="static/admin/data/".$filename; //指定要恢复的MySQL备份文件路径,请自已修改此路径
// print_r($mysql_file);die;
$this->restore($mysql_file); //执行MySQL恢复命令
}
function restore($fname)
{
if (file_exists($fname)) {
$sql_value="";
$cg=0;
$sb=0;
$sqls=file($fname);
foreach($sqls as $sql)
{
$sql_value.=$sql;
}
$a=explode(";\r\n", $sql_value); //根据";\r\n"条件对数据库中分条执行
$total=count($a)-1;
mysql_query("set names 'utf8'");
for ($i=0;$i<$total;$i++)
{
mysql_query("set names 'utf8'");
//执行命令
if(mysql_query($a[$i]))
{
$cg+=1;
}
else
{
$sb+=1;
$sb_command[$sb]=$a[$i];
}
}
echo "操作完毕,共处理 $total 条命令,成功 $cg 条,失败 $sb 条";
//显示错误信息
if ($sb>0)
{
echo "<hr><br><br>失败命令如下:<br>";
for ($ii=1;$ii<=$sb;$ii++)
{
echo "<p><b>第 ".$ii." 条命令(内容如下):</b><br>".$sb_command[$ii]."</p><br>";
}
} //-----------------------------------------------------------
}else{
echo "MySQL备份文件不存在,请检查文件路径是否正确!";
}
}

转载于:https://www.cnblogs.com/xin521/p/9077021.html

php 数据库备份还原相关推荐

  1. [整理] C#调用SQLDMO.DLL时间数据库备份 / 还原。 (香神无涯) // C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)...

    /// <summary> /// 通过调用MSSQL的SQLDMO.DLL文件来实现备份数据库 /// 1.首先在在项目中引用SQLDMO.DLL文件. /// 2.在引用中的SQLDM ...

  2. php备份和恢复源码,PHP数据库备份还原类

    php代码<?php /** * 数据库备份还原类 * @author xialeistudio* @date 2014-03-17 * Class DatabaseTool */ class ...

  3. php7数据库备份还原,基于thinkphp的数据库在线备份还原

    搜索了不少资料,东拼西凑总算完成了.下面贴出来代码,原理就不讲解了,代码挺简单的,重要部分我都做了注释.<?php use Think\Db; /** * 数据库备份还原类 * @author  ...

  4. [ MySQL ] 使用Navicat进行MySQL数据库备份 / 还原(Part 2:备份.sql文件方式)

    本文主要讲解如何用Navicat(Navicat Premium ,或者Navicat for mysql)进行MySQL备份和恢复数据库(利用.sql文件的方式). 关于MySQL数据库备份,本博客 ...

  5. 十一、MYSQL数据库备份还原

    十一.MYSQL数据库备份还原 数据库冷备份 mysqldump备份和还原数据库 备份 主从数据库备份 备份指定数据库 备份多个数据库 备份所有数据库 备份数据表 方法1: `mysqldump`备份 ...

  6. 数据库备份还原与分离附加

    备份还原数据库与分离附加数据库 备份还原数据库与分离附加数据库有什么区别呢?字面意义上可以看出,备份还原是在本地服务器上进行操作,主要是讲本机数据进行备份,以防数据丢失找不回来.分离数据库是指从本地服 ...

  7. MySQL 单个数据库备份还原

    数据库备份还原 MYISAM:  --lock-all-tables INNODB: --single-transaction #单个数据库备份及压缩 mysqldump -uroot -pmysql ...

  8. [ MySQL ] 使用Navicat进行MySQL数据库备份 / 还原(Part 1:备份.nb3文件方式)

    本文主要讲解如何用Navicat(Navicat Premium ,或者Navicat for mysql)进行MySQL备份和恢复数据库. 本文主要大纲为:使用Navicat备份工具方式进行备份和还 ...

  9. MYSQL数据库备份还原,并还原到最新状态(mysqldump,xtrabackup)

    启用二进制日志文件 vim /etc/my.cnf 配置文件位置及文件名根据实际情况确定 sql_log_bin=ON|OFF:是否记录二进制日志,默认为ON //在需要的时候设置为OFF log_b ...

  10. Navicat数据库备份还原

    Navicat数据库备份包括数据和架构 还原数据库:把备份文件复制到备份文件夹所在位置,还原即可 转载于:https://www.cnblogs.com/shiruina/p/9320794.html

最新文章

  1. 一、nginx 安装
  2. 【Android 内存优化】垃圾回收算法 ( 内存优化总结 | 常见的内存泄漏场景 | GC 算法 | 标记清除算法 | 复制算法 | 标记压缩算法 )
  3. java 动态代理深度学习(Proxy,InvocationHandler)
  4. 算法分析 运动员循环赛_「98跑」大众跑者的训练比专业运动员更累!
  5. linux namespace 工具,Linux Namespace : 简介
  6. SQLServer2008内存飙升 解决
  7. sublime设置自己的快捷键
  8. camera (13)---智能手机双摄像头工作原理详解:RBG +RGB, RGB + Mono
  9. php网页事件处理方法,PHP实现事件机制的方法
  10. linux常用命令示例
  11. 计算机风扇维修,电脑风扇轴承磨损的简易维修方法
  12. 计算机网络基础知识题,计算机网络基础知识试题及答案
  13. 小米手机获取完整ROOT权限教程
  14. 酚酸靶向助力组合消毒剂在新鲜农产品中的应用研究
  15. Element 中图片预览后如何快速关闭
  16. 易语言c语言哪个做游戏脚本,易语言游戏脚本写法源码
  17. 高中计算机考试操作题ftp,计算机考试实操题-高中课件精选.doc
  18. iPad 3 即将发布,网传价格,IPD2降价50$ 新功能猜测
  19. Elasticsearch(9) --- 聚合查询(Bucket聚合)
  20. Spring Boot请求403 Forbidden错误

热门文章

  1. IMA-ADPCM 算法
  2. ubuntu下C语言打开bmp图像文件并读取数据
  3. 一种简单的图像显著性计算模型
  4. 【LeetCode】【字符串】题号:*451. 根据字符出现频率排序
  5. C#中如何跨窗体传值
  6. ENVI实现归一化建筑物指数(NDBI)实验操作
  7. Python 读取MODIS叶绿素-a浓度.nc文件
  8. TM数据单窗算法和单通道算法反演地表温度(IDL实现)
  9. Android GC机制介绍
  10. ajax 请求与响应,实例解读ajax发送请求与数据响应