php mysql 备份还原_php 数据库备份还原
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 "";
}
这里的数据恢复需要和上面的数据备份配套
这里的数据还原需要传文件名以及文件路径
//数据恢复
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
{
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 "
失败命令如下:
";
for ($ii=1;$ii<=$sb;$ii++)
{
echo "
第 ".$ii." 条命令(内容如下):
".$sb_command[$ii]."
";
}
} //-----------------------------------------------------------
}else{
echo "MySQL备份文件不存在,请检查文件路径是否正确!";
}
}
php mysql 备份还原_php 数据库备份还原相关推荐
- SQL Server 2008还原数据库时出现“备份集中的数据库备份与现有的数据库不同”的解决方法
SQL Server 2008还原数据库时出现"备份集中的数据库备份与现有的数据库不同"的解决方法 参考文章: (1)SQL Server 2008还原数据库时出现"备份 ...
- restore还原不同名称的数据库_Sql Server 备份还原失败错误ERROR:3145(备份集中的数据库备份与现有的数据库不同)及解决办法...
一.前言 SQL Server 备份和还原全攻略,里面包括了通过SSMS操作还原各种备份文件的图形指导,SQL Server 数据库最小宕机迁移方案,里面使用SQL脚本(T-SQL)完成完全备份.差异 ...
- sql2008“备份集中的数据库备份与现有的xx数据库不同”解决方法 因为是在另一台电脑对同名数据库做的备份,用常规方法还原,提示不是相同数据库,不让还原,在网上找到下面的方法解决了: 一、右击系
sql2008"备份集中的数据库备份与现有的xx数据库不同"解决方法 因为是在另一台电脑对同名数据库做的备份,用常规方法还原,提示不是相同数据库,不让还原,在网上找到下面的方法解决 ...
- SQL Server 2005“备份集中的数据库备份与现有的数据库不同”解决方法此信息转载自BlueSky's Blog,www.heuupk.com,为尊重无价的知识请保留此版权信息。...
SQL Server 2005"备份集中的数据库备份与现有的数据库不同"解决方法 以前一直使用SQL Server2000,现在使用SQL Server2005,就在现在的项目中使 ...
- SQL2005备份集中的数据库备份与现有的数据库不同,错误号码:3154,解决方法...
今天还原一个SQL Server 2005备份文件: 1.新建数据库名"test1": 2.从备份文件"kingdb.bak"恢复. 但是提示"备份集 ...
- “备份集中的数据库备份与现有的数据库不同”解决方法
原文发布时间为:2010-09-16 -- 来源于本人的百度文章 [由搬家工具导入] 最主要就是要在"选项"中选择"覆盖现有数据库",否则就会出现"备 ...
- SQL数据库还原时备份集中的数据库备份与现有的数据库不同的解决办法
SQL Server 2005数据库还原出错 错误具体信息为:备份集中的数据库备份与现有的A数据库不同 具体操作如下: 第一次:新建了数据库A,数据库文件放在E:\DB\A目录下,选中该数据库右键-任 ...
- sql2008备份集中的数据库备份与现有的xxx数据库不同解决方法
sql2008备份集中的数据库备份与现有的xxx数据库不同解决方法 原文链接:https://wncbl.cn/54.html 问题描述 今天在配置一个 ASP 站点时,导入以前的数据库备份文件,提示 ...
- tsm备份mysql_TSM自身数据库备份失败
TSM服务器由于故障,更换过raid卡,修改过IP地址,之后自身db2数据库就无法进行备份了. 各客户端节点可以通过它正常备份到磁带库库,服务器自身备份到磁盘. 请大侠们帮忙看看是什么问题,非常感谢. ...
最新文章
- python数组转换为列表_python - 将一系列数组转换为单个列表 - SO中文参考 - www.soinside.com...
- Opensmile 简介
- python flask route中装饰器的使用
- 7 个习惯帮你提升Python运行性能
- java web 测试类,构建一个容易单元测试的java–web系统-JSP教程,Java技巧及代码
- wince 环境变量
- C语言srand((unsigned)time(NULL))…
- iview组件的Table表格的内容过多时,显示title提示
- 崩坏学园2及大部分采用ETC1压缩格式的Unity3D游戏的拆包图处理
- iOS开发之阿里百川、京东联盟、多多客联盟(拼多多)的接入
- 测试用例场景法3个例子
- eda数字竞赛抢答器
- tftp: timeout
- iperf3网络测速
- 今天正式开始做毕业设计——自助装机系统
- excel中以文本形式保存长数字
- 01-使用EasyExcel读取和写入Excel文件
- PXE实现系统批量自动安装
- 从小白到web渗透工程师——零基础指南(1)web渗透工程师介绍
- 我的RUST学习—— 【第十章 10-2】trait:定义共享行为
热门文章
- Error: 未绑定为第三方平台的开发小程序
- android安全攻防实践_网络攻防小组招新,等待优秀的你!
- OpenCV算子速查表(持续更新)
- FreeRTOS之Tracealyzer for FreeRTOS(FreeRTOS+Trace) 详解(源码解析+移植)
- Linux常见服务构建
- MySQL安装与java配合
- Android反射修改view,Android 修改viewpage滑动速度的实现代码
- appim自动化--点击指定控件的指定位置
- SQL SERVER 系列(2)数据库的创建、修改和删除
- XP---VS05---部署个人网站初学者工具包---方案