php在线备份和恢复数据库(mysql数据库备份与恢复)

本文目录一览:

php 代码备份数据库

?php

/*

**************function db_bak()********************

*  功能:备份指定的数据库中的指定表

*  输入(按传入参数解释):$db_name 要备份的数据库,$tb_array要备份的表,数组形式的,如果不是数组,将备份整个库。

  $dir输出备份文件的目录,$filename备份文件名,$block_num指定分块大小(指一条insert语句包含几天数据)

*  输出:备份的数据表的sql语句文件,可用于还原

*/

function db_bak($mylink,$dbname,$tab_array=””,$dir,$filename,$block_num=20){

 mysql_select_db($dbname,$mylink) or db_error(mysql_error());

 is_array($tab_array) or $tab_array=db_showtb($mylink,$dbname,true); //如果$tab_array不是数组,则取得整个库的表

 if($dir){

  if(!file_exists($dir)){

   $flag=mkdir($dir);

   if(!$flag)

    return 2;

  }

 }

 //检查数据表是否存在

 foreach($tab_array as $tab)

  db_e_tab($mylink,$dbname,$tab) or db_error($tab.” is not exist!”);

 $fp=fopen($dir.$filename,”w”);

 foreach($tab_array as $tab){  

  fputs($fp,”DROP TABLE IF EXISTS “.$tab.”;\r\n”);

  $tabdef_array=mysql_fetch_array(mysql_query(“SHOW CREATE TABLE “.$tab,$mylink));

  fputs($fp,str_replace(“\n”,””,$tabdef_array[“Create Table”]).”;\r\n”); 

  fputs($fp,”LOCK TABLES “.$tab.” WRITE;\r\n”); 

  $getvalue_result=mysql_query(“select * from “.$tab,$mylink);

  if(mysql_num_rows($getvalue_result)){

   $i=1;  

   $p=””;

   $start_flag=true;

   while($getvalue_array=mysql_fetch_row($getvalue_result)){

    $values=join(“‘,'”,array_map(‘db_data_check’,$getvalue_array));

    $start_flag  fputs($fp,”insert into “.$tab.” values”);

    if($i$block_num){

     fputs($fp,”,(‘”.$values.”‘);\r\n”);

     $start_flag=true;

     $i=0;

    }else{

     fputs($fp,$p.”(‘”.$values.”‘)”);

     $start_flag=false;

     $i++;

    }

    $p=$start_flag?””:”,”; 

   }

   $start_flag or fputs($fp,”;\r\n”);

  }

  fputs($fp,”UNLOCK TABLES;\r\n”);  

 }

 fclose($fp);  

}

/*

**************function db_in()********************

*  功能:还原备份函数db_bak生成的数据库文件

*  输入(按传入参数解释):$db_name 要备份的数据库,$filename要还原的数据库文件

*  输出:将数据还原到数据库

*  原理:将文件分割成一个数组,然后逐条将数据导入数据库

*  警告:执行该函数会删除原来的数据表

*/

function db_in($mylink,$dbname,$filename){

 if(!file_exists($filename)){

  return 0;

 }

 db_e_db($mylink,$dbname) or (mysql_query(“create database “.$dbname,$mylink)or db_error(mysql_error()));

 mysql_select_db($dbname,$mylink);

 $sql_array=file($filename);

 foreach($sql_array as $sql){

  mysql_query(trim($sql),$mylink) or db_error(mysql_error());

 }

}

//我自己写的。可以参考哈

php+mysql如何在后台备份恢复数据库,我是新手

1,恢复前备份。2,有之前的备份才可以恢复。3,下载数据库管理工具,sqlyun,navcat,等可进行导入导出。4.注意恢复期间对前台影响。(最好关闭前台访问)5.做好出问题时的应对准备

php怎么备份数据库

1.打开数据库备份页面

//php代码,导出数据库

public function exportSql() {

$dbName = C(‘DB_NAME’); //读取配置文件中的数据库用户名、密码、数据库名

$dbUser = C(‘DB_USER’);

$dbPwd = C(‘DB_PWD’);

$fileName = date(“Y-m-d”).”_”.$dbName.”.sql”;

$dumpFileName = “./sql_backup/”.$fileName;

exec(“D:/xampp/mysql/bin/mysqldump -u$dbUser -p$dbPwd $dbName $dumpFileName”);

}

2.php exec函数,执行外部程序命令

exec(“D:/xampp/mysql/bin/mysqldump -u$dbUser -p$dbPwd $dbName $dumpFileName”);

此处执行mysqldump命令,导出数据库到$dumpFileName中,“D:/xampp/mysql/bin/”为mysqldump所在位置,“-u$dbUser -p$dbPwd”数据库的用户名和密码(中间不要加空格),$dbName为要导出数据库的名字

原创文章,作者:WRPUS,如若转载,请注明出处:https://www.506064.com/n/329911.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
WRPUSWRPUS
上一篇 2025-01-14 18:55
下一篇 2025-01-14 18:55

相关推荐

  • PHP和Python哪个好找工作?

    PHP和Python都是非常流行的编程语言,它们被广泛应用于不同领域的开发中。但是,在考虑择业方向的时候,很多人都会有一个问题:PHP和Python哪个好找工作?这篇文章将从多个方…

    编程 2025-04-29
  • Python 常用数据库有哪些?

    在Python编程中,数据库是不可或缺的一部分。随着互联网应用的不断扩大,处理海量数据已成为一种趋势。Python有许多成熟的数据库管理系统,接下来我们将从多个方面介绍Python…

    编程 2025-04-29
  • openeuler安装数据库方案

    本文将介绍在openeuler操作系统中安装数据库的方案,并提供代码示例。 一、安装MariaDB 下面介绍如何在openeuler中安装MariaDB。 1、更新软件源 sudo…

    编程 2025-04-29
  • PHP怎么接币

    想要在自己的网站或应用中接受比特币等加密货币的支付,就需要对该加密货币拥有一定的了解,并使用对应的API进行开发。本文将从多个方面详细阐述如何使用PHP接受加密货币的支付。 一、环…

    编程 2025-04-29
  • 数据库第三范式会有删除插入异常

    如果没有正确设计数据库,第三范式可能导致删除和插入异常。以下是详细解释: 一、什么是第三范式和范式理论? 范式理论是关系数据库中的一个规范化过程。第三范式是范式理论中的一种常见形式…

    编程 2025-04-29
  • leveldb和unqlite:两个高性能的数据库存储引擎

    本文将介绍两款高性能的数据库存储引擎:leveldb和unqlite,并从多个方面对它们进行详细的阐述。 一、leveldb:轻量级的键值存储引擎 1、leveldb概述: lev…

    编程 2025-04-28
  • Python怎么导入数据库

    Python是一种高级编程语言。它具有简单、易读的语法和广泛的库,让它成为一个灵活和强大的工具。Python的数据库连接类型可以多种多样,其中包括MySQL、Oracle、Post…

    编程 2025-04-28
  • 使用PHP foreach遍历有相同属性的值

    本篇文章将介绍如何使用PHP foreach遍历具有相同属性的值,并给出相应的代码示例。 一、基础概念 在讲解如何使用PHP foreach遍历有相同属性的值之前,我们需要先了解几…

    编程 2025-04-28
  • Python在线编辑器的优势与实现方式

    Python在线编辑器是Python语言爱好者的重要工具之一,它可以让用户方便快捷的在线编码、调试和分享代码,无需在本地安装Python环境。本文将从多个方面对Python在线编辑…

    编程 2025-04-28
  • 用什么来备份 ssbackup 文件?

    SSBackup是一种用于存储数据的文件格式,可以在Snapshots和Debian GNU / Linux系统上使用。备份文件是大多数用户和数据中心管理员的关键需求。通过备份,可…

    编程 2025-04-27

发表回复

登录后才能评论