您当前的位置: 首页 > 网站编程 > PHP教程 > 使用PHP备份MYSQL数据的多种方法

使用PHP备份MYSQL数据的多种方法

作者:不详 来源:网络 发布时间: 2014-08-11 21:03 点击:
通常情况下,我们都是使用工具备份,比如phpmyadmin、navicat。如果需要使用PHP备份,如何实现呢 下面提供两种方法,仅供研究使用。 第1种方法: 代码如下: ?php $host=localhost; $user=root; $password=; $dbname=dbname; mysql_connect($host,$user,$password); mys

使用PHP备份MYSQL数据的多种方法

  通常情况下,我们都是使用工具备份,比如phpmyadmin、navicat。如果需要使用PHP备份,如何实现呢

  下面提供两种方法,仅供研究使用。

  第1种方法:

  代码如下:

  <?php

  $host="localhost";

  $user="root";

  $password="";

  $dbname="dbname";

  mysql_connect($host,$user,$password);

  mysql_select_db($dbname);

  $mysql= "set names utf8;";

  mysql_query($mysql);

  $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'].";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);n";

  }

  $mysql.="n";

  }

  $filename=$dbname.date('Ymj').".sql";

  $fp = fopen($filename,'w');

  fputs($fp,$mysql);

  fclose($fp);

  echo "数据备份成功,生成备份文件".$filename;

  ?>

  第2种方法:

  代码如下:

  <?php

  $host="localhost";

  $user="root";

  $password="";

  $dbname="dbname";

  backup_tables($host,$user,$password,$dbname);

  /* backup the db OR just a table */

  function backup_tables($host,$user,$pass,$name,$tables = '*')

  {

  $link = mysql_connect($host,$user,$pass);

  mysql_select_db($name,$link);

  //get all of the tables

  if($tables == '*')

  {

  $tables = array();

  $result = mysql_query('SHOW TABLES');

  while($row = mysql_fetch_row($result))

  {

  $tables[] = $row[0];

  }

  }

  else

  {

  $tables = is_array($tables) ? $tables : explode(',',$tables);

  }

  $return = '';

  //cycle through

  foreach($tables as $table)

  {

  $result = mysql_query('SELECT * FROM '.$table);

  $num_fields = mysql_num_fields($result);

  $return.= 'DROP TABLE '.$table.';';

  $row2 = mysql_fetch_row(mysql_query('SHOW CREATE TABLE '.$table));

  $return.= "nn".$row2[1].";nn";

  for ($i = 0; $i < $num_fields; $i++)

  {

  while($row = mysql_fetch_row($result))

  {

  $return.= 'INSERT INTO '.$table.' VALUES(';

  for($j=0; $j<$num_fields; $j++)

  {

  $row[$j] = addslashes($row[$j]);

  $row[$j] = ereg_replace("n","n",$row[$j]);

  if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; }

  if ($j<($num_fields-1)) { $return.= ','; }

  }

  $return.= ");n";

  }

  }

  $return.="nnn";

  }

  //save file

  $handle = fopen('db-backup-'.time().'-'.(md5(implode(',',$tables))).'.sql','w+');

  fwrite($handle,$return);

  fclose($handle);

  }

  ?>
分享到:
本文"使用PHP备份MYSQL数据的多种方法"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 广告合作 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4