当前位置:Gxlcms > PHP教程 > 一个简单php数据库备份程序_PHP教程

一个简单php数据库备份程序_PHP教程

时间:2021-07-01 10:21:17 帮助过:12人阅读

php备份mysql数据库是很多个人站长网站所具备的功能,当然如果你要备份几个GB或更大的数据库时php备份方法感觉有点吃力了。

PHP 备份 mysql 数据库的源代码,在完善的 PHP+Mysql 项目中,在后台都会有备份 Mysql 数据库的功能,有了这个功能,我们就不用再使用 FTP 或者使用 mysql 的管理工具进行 mysql 数据库下载了,非常方便,对于想做这样功能的 phper 来说,其实原理并不是很麻烦,主要有以下三点:

一,一定要连接数据库,这样才能通过 SQL 语句打印出 mysql 数据表,二,通过 PHP 的文件操作函数进行数据库的操作,包括创建保存 mysql 数据库的文件夹,这一步主要就是新建文件的步骤,三,将 mysql 数据库进行保存下来。

通过这样的原理,我们就可以制作出一个属于自己的备份数据库的功能了,下面是一个php数据库备份的源代码,主要结构是依据上面的三点进行的,源码是由几个方法组成的,我们也可以将其封装成为自己的 php 类。举一反三,希望 phper 能在此基础上设计出适合自己的 mysql 数据库备份功能源码

代码如下

/** 备份数据库 生成.sql文件
* @param $browseinfo String 浏览器版本
* return $browseinfo
*/
function createsql(){
//创建个日期
$timer1 = time();
$path = "my_sql/";
$content =gettables();
$filename = $path.$timer1.".sql";

//先判断文件夹在不在
if(!file_exists($path)){
//如果不存在生成这个目录,0777表示最大的读写权限
if(mkdir($path,0777)){
//echo"新建立目录";
}
}

//判断文件是否存在
if(!file_exists($filename)){
//如果文件不存在,则创建文件
@fopen($filename,"w");

//判断文件是否可写
if(is_writable($filename)){
//打开文件以添加方式即"a"方式打开文件流
if(!$handle = fopen($filename,"a")){
echo"文件不可打开";
exit();
}

if(!fwrite($handle,$content)){
echo"文件不可写";
exit();
}

//关闭文件流
fclose($handle);
echo "生成文件并保存首次内容";

}else {
echo"文件$filename不可写";
}
}else{
if(is_writable($filename)){
//以添加方式打开文件流
if(!$handle = fopen($filename,"a")){
echo"文件不可打开";
exit();
}
fclose($handle);
}else{
echo "文件$filename不可写";
}
}
}


/**
* 获得数据库中的表名
* return $str 循环生成数据库建表和插入值的sql语句
*/
function gettables(){
$mysqli = new mysqli("localhost","root","","bbs");
$str = '';
if ($result = $mysqli->query("SHOW TABLES")) {
while($row = $result->fetch_row()){
$str.= data2sql($row[0])."
";
}
$mysqli->close();
return $str;
}

}

/**
* 获得数据库中的表结构和值
* return $tabledump 返回一个表中的结构和值的sql语句
*/
function data2sql($table){
$mysqli = new mysqli("localhost","root","","bbs");
/* check connection */
if (mysqli_connect_errno()) {
printf("Connect failed: %sn", mysqli_connect_error());
exit();
}
$tabledump = "DROP TABLE IF EXISTS $table;n";
$result = $mysqli->query("SHOW CREATE TABLE $table");
$create = $result->fetch_row();
$tabledump .= $create[1].";nn";

$rows = $mysqli->query("SELECT * FROM $table");
$numfields = $rows->num_rows;

while ($row = $rows->fetch_row()){
$comma = "";
$tabledump .= "INSERT INTO $table VALUES(";
for($i = 0; $i < $numfields; $i++)
{
$tabledump .= $comma."'".mysql_escape_strin
g($row[$i])."'";
$comma = ",";
}
$tabledump .= ");n";
}
$tabledump .= "n";

return $tabledump;
}
?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/632928.htmlTechArticlephp备份mysql数据库是很多个人站长网站所具备的功能,当然如果你要备份几个GB或更大的数据库时php备份方法感觉有点吃力了。 PHP 备份 mys...

人气教程排行