php实现mysql数据库的备份与还原的方法,在日常的php编程中经常用得到
备份数据库还原数据库
备份数据库
- <?php
- $host="localhost";
- $user="####";//数据库账号
- $password="###";//数据库密码
- $dbname="###";//数据库名称
- //这里的账号、密码、名称都是从页面传过来的
- if(!mysql_connect($host,$user,$password)) //连接mysql数据库
- {
- echo '数据库连接失败,请核对后再试';
- exit;
- }
- if(!mysql_select_db($dbname)) //是否存在该数据库
- {
- echo '不存在数据库:'.$dbname.',请核对后再试';
- exit;
- }
- //$mysql= "set charset utf8;\r\n";
- $q1=mysql_query("show tables");
- while($t=mysql_fetch_array($q1)){
- $table=$t[0];
- $q2=mysql_query("show create table `$table`");
- $sql=mysql_fetch_array($q2);
- $mysql.=$sql['Create Table'].";\r\n";
- $q3=mysql_query("select * from `$table`");
- while($data=mysql_fetch_assoc($q3)){
- $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";
- }
- }
- $filename="../bak/".$_POST[b_name]; //存放路径,默认存放到项目最外层
- $fp = fopen($filename,'w');
- fputs($fp,$mysql);
- fclose($fp);
- ?>
- <?php
- $filename = $_POST[r_name];
- $host="localhost"; //主机名
- $user="root"; //MYSQL用户名
- $password="1234"; //密码
- $dbname="db_office"; //在此指定您要恢复的数据库名,不存在则必须先创建,请自已修改数据库名
- $conns=mysql_connect($host,$user,$password);
- mysql_select_db($dbname);
- $result = mysql_query("show table status from $dbname",$conns);
- while($data=mysql_fetch_array($result)) {
- mysql_query("drop table $data[Name]");
- }
- $mysql_file="../bak/".$filename; //指定要恢复的MySQL备份文件路径,请自已修改此路径
- 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 "<script>alert('操作完毕,共处理 $total 条命令,成功 $cg 条,失败 $sb 条');location='data_stock.php'</script>";
- //显示错误信息
- 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备份文件不存在,请检查文件路径是否正确!";
- }
- }
- ?>
"小礼物走一走,来肥宅自学平台支持我"
评论区
共条评论
- 这篇文章还没有收到评论,赶紧来抢沙发吧~
首页上页1下页尾页