//

Information for details

php对mysql数据库的备份及还原

以下仅供学习和参考。


//备份数据库
$host="localhost";  
$user=trim($_POST['user']);//数据库账号
$password=trim($_POST['password']);//数据库密码
$dbname=trim($_POST['dbname']);//数据库名称

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];
    $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="uploads/mysql_bak/".$dbname.date('Ymjgi').".sql";  //存放路径,默认存放到项目最外层
$fp = fopen($filename,'w');
fputs($fp,$mysql);
fclose($fp);
echo "数据备份成功";


//恢复数据库
<?Php
$filename = $_POST['restore'];
$host="localhost"; //主机名
$user="root"; //MYSQL用户名
$password="admin"; //密码
$dbname="thinkphp"; //在此指定您要恢复的数据库名,不存在则必须先创建,请自已修改数据库名
mysql_connect($host,$user,$password);
mysql_select_db($dbname);
$mysql_file="uploads/mysql_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;
            for ($i=0;$i<$total;$i++)
            {
                //执行命令
                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备份文件不存在,请检查文件路径是否正确!";
        }
    }
?>

云南然成科技有限公司是一家定位于高端网站建设、系统开发、APP开发、软件定制的高新科技公司。我们的团队成员曾来自不同行业,拥有不同背景,公司成立之前,都在互联网行业从事相关工作多年,一直奋斗在APP开发、微信开发、系统开发、商城网站开发第一线。多年的累积是一种财富,我们擅于运用所知所得诠释他们眼中的认知,更善于站在客户的立场上去思考,跨界创新,整合设计。

  • 滇公网安备 53010202001388号