最新活动:电脑PC端+手机端+微网站+自适应网页多模板选择-建站388元起价!!!
当前位置:主页 > 网站建设 > 详解MYSQL的备份还原(PHP实现)建站知识

详解MYSQL的备份还原(PHP实现)建站知识

时间:2023-05-23 23:05:23 阅读: 文章分类: 网站建设 作者: 网站技术员

导读:1建站知识手把手教你实现MYSQL的备份还原 示例代码用我比较熟悉的PHP,当然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的语言自己写出来。 一、新建dbBac网站建设高端网站建设。

网站建设高端网站建设手把手教你实现MYSQL的备份还原 示例代码用我比较熟悉的PHP,当然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的语言自己写出来。 一、新建dbBackup类,设置默认参数。 , 0, -1)、mb_substr($sql, 0, -3),必须去除最后一个逗号(,) 否则SQL语句出错5.$sql.=";-- <xjx> --\r\n\r\n",详见第四步注   六、备份操作   复制代码 代码如下:     /** * 备份 ... * @param $filename 文件路径 */ function beifen($filename) { $this->db(); //连接数据库   $sql=$this->sqlcreate(); $sql2=$this->sqlinsert();  $data=$sql.$sql2;   return file_put_contents($filename, $data); }     七、还原操作 复制代码 代码如下:     /** * 还原 ... * @param $filename 文件路径 */ function huanyuan($filename) { $this->db(); //连接数据库   //删除数据表 $list=$this->tblist(); $tb=''; foreach ($list as $v) { $tb.="`$v`,"; } $tb=mb_substr($tb, 0, -1); if ($tb) { $rs=mysql_query("DROP TABLE $tb"); if ($rs===false) { return false; } }   //执行SQL $str=file_get_contents($filename); $arr=explode('-- <xjx> --', $str); array_pop($arr);   foreach ($arr as $v) { $rs=mysql_query($v); if ($rs===false) { return false; } }   return true; }     备份示例: 复制代码 代码如下:     $x=new dbBackup(); $x->database='test'; $rs=$x->beifen('db.sql'); var_dump($rs);     还原示例: 网站优化seo培训 复制代码 代码如下:     $x=new dbBackup(); $x->database='test'; $rs=$x->huanyuan('db.sql'); var_dump($rs);     完整代码: 复制代码 代码如下:     class dbBackup { public $host='localhost'; //数据库地址 public $user='root'; //登录名 public $pwd=''; //密码 public $database; //数据库名 public $charset='utf8'; //数据库连接编码:mysql_set_charset   /** * 备份 ... * @param $filename 文件路径 */ function beifen($filename) { $this->db(); //连接数据库   $sql=$this->sqlcreate(); $sql2=$this->sqlinsert();  $data=$sql.$sql2;   return file_put_contents($filename, $data); }   /** * 还原 ... * @param $filename 文件路径 */ function huanyuan($filename) { $this->db(); //连接数据库   //删除数据表 $list=$this->tblist(); $tb=''; foreach ($list as $v) { $tb.="`$v`,"; } $tb=mb_substr($tb, 0, -1); if ($tb) { $rs=mysql_query("DROP TABLE $tb"); if ($rs===false) { return false; } }   //执行SQL $str=file_get_contents($filename); $arr=explode('-- <xjx> --', $str); array_pop($arr);   foreach ($arr as $v) { $rs=mysql_query($v); if ($rs===false) { return false; } }   return true; }   /** * 连接数据库 ... */ function db() {  $con = mysql_connect($this->host,$this->user,$this->pwd); if (!$con){ die('Could not connect'); }   $db_selected = mysql_select_db($this->database, $con); i网站建设多少钱f (!$db_selected) { die('Can\'t use select db'); }   mysql_set_charset($this->charset); //设置编码   return $con; }   /** * 表集合 ... */ function tblist() { $list=array();   $rs=mysql_query("SHOW TABLES FROM $this->database"); while ($temp=mysql_fetch_row($rs)) { $list[]=$temp[0]; }   return $list; }   /** * 表结构SQL ... */ function sqlcreate() { $sql='';   $tb=$this->tblist();  foreach ($tb as $v) { $rs=mysql_query("SHOW CREATE TABLE $v"); $temp=mysql_fetch_row($rs); $sql.="-- 表的结构:{$temp[0]} --\r\n"; $sql.="{$temp[1]}"; $sql.=";-- <xjx> --\r\n\r\n"; } return $sql; }   /** * 数据插入SQL ... */ function sqlinsert() { $sql='';   $tb=$this->tblist();  foreach ($tb as $v) { $rs=mysql_query("SELECT * FROM $v"); if (!mysql_num_rows($rs)) {//无数据返回 continue; }  $sql.="-- 表的数据:$v --\r\n"; $sql.="INSERT INTO `$v` VALUES\r\n";  while ($temp=mysql_fetch_row($rs)) { $sql.='('; foreach ($temp as $v2) { if ($v2===null) { $sql.="NULL,"; } else { $v2=mysql_real_escape_string($v2); $sql.="'$v2',"; }  } $sql=mb_substr($sql, 0, -1)网站seo优化; $sql.="),\r\n"; } $sql=mb_substr($sql, 0, -3); $sql.=";-- <xjx> --\r\n\r\n";  }   return $sql; } } //备份 //$x=new dbBackup(); //$x->database='test'; //$rs=$x->beifen('db.sql'); //var_dump($rs); //还原 //$x=new dbBackup(); //$x->database='test'; //$rs=$x->huanyuan('db.sql'); //var_dump($rs);相关网站建设高端网站建设。

关键词标签: 详解 SQL 备份

声明: 本文由我的SEOUC技术文章主页发布于:2023-05-23 ,文章详解MYSQL的备份还原(PHP实现)建站知识主要讲述详解,备份,SQL网站建设源码以及服务器配置搭建相关技术文章。转载请保留链接: https://www.seouc.com/article/web_6169.html

我的IDC 网站建设技术SEOUC.COM
专注网站建设,SEO优化,小程序设计制作搭建开发定制网站等,数千家网站定制开发案例,网站推广技术服务。
  • 5000+合作客服
  • 8年从业经验
  • 150+覆盖行业
  • 最新热门源码技术文章