php实现备份mysql数据库
作者: Knight
想在php后台管理直接能够备份数据库,于是想呀想,一直没有什么思路,一开始是考虑用php来访问服务器安装mysql的目录,比如 /usr/local/mysql/data目录,直接把下面对应的文件进行备份,但是出现了问题:
第一、运行php的是apche的用户,比如是nobody,那么它一般是没有权限访问/usr/local/mysql/data目录的
第二、就算能够访问,那么你如何能够把/usr/local/mysql/data目录下的文件拷贝出来呢?因为mysql在运行的时候是不运行访问的,那么nobody用户有权限停止mysql的服务,不可能!
越想越不对劲,没有办法,看能不能从php操作数据库入手,于是就去看了下phpMyadmin和Discuz!的代码,呵呵,于是偷抄了Discuz!的代码,形成了如下备份数据库的方法。(在这里感谢Discuz!的开发者)
备份数据库有两种方式,一种是只备份数据库的结构,一种把是结构和所有的数据都备份出来,当然是第二种方法好啦,不过我为了考虑可能的需求就都作啦。
/****** 备份数据库结构 ******/
/*
函数名称:table2sql()
函数功能:把表的结构转换成为SQL
函数参数:$table: 要进行提取的表名
返 回 值:返回提取后的结果,SQL集合
函数作者:heiyeluren
*/
function table2sql($table)
{
global $db;
$tabledump = "DROP TABLE IF EXISTS $table; ";
$createtable = $db->query("SHOW CREATE TABLE $table");
$create = $db->fetch_row($createtable);
$tabledump .= $create[1]."; ";
return $tabledump;
}
/****** 备份数据库结构和所有数据 ******/
/*
函数名称:data2sql()
函数功能:把表的结构和数据转换成为SQL
函数参数:$table: 要进行提取的表名
返 回 值:返回提取后的结果,SQL集合
函数作者:heiyeluren
*/
function data2sql($table)
{
global $db;
$tabledump = "DROP TABLE IF EXISTS $table; ";
$createtable = $db->query("SHOW CREATE TABLE $table");
$create = $db->fetch_row($createtable);
$tabledump .= $create[1]."; ";
$rows = $db->query("SELECT * FROM $table");
$numfields = $db->num_fields($rows);
$numrows = $db->num_rows($rows);
while ($row = $db->fetch_row($rows))
{
$comma = "";
$tabledump .= "INSERT INTO $table VALUES(";
for($i = 0; $i {
$tabledump .= $comma."".mysql_escape_string($row[$i])."";
$comma = ",";
}
$tabledump .= "); ";
}
$tabledump .= " ";
return $tabledump;
}
/****** 具体实现操作 ******/
好,我们既然把代码都写出来了,那么我们如何在具体的程序种去实现备份呢,我们看下面的代码。
/* 备份数据库 */
// 注意:我们一下的数据库操作采用了phplib的DB类
// 定义要保存的数据表、前缀、保存到何处
$tables = array(us_sort, us_download, us_article, us_guestbook); //定义要保存的数据表,一个数组
$prefix = us_; // 要保存的.sql文件的前缀
$saveto = server; // 要保存到什么地方,是本地还是服务器上,默认是服务器
$back_mode = all; // 要保存的方式,是全部备份还是只保存数据库结构
$admin = heiyeluren; //管理员名称
$admin_email = heiyeluren@163.com; // 管理员邮箱
// 定义数据保存的文件名
$local_filename = $prefix.date(Ymd_His)..sql";
if (!$filename) { $filename = $db_backup_path . $prefix . date(Ymd_His_). create_check_code(4) . ".sql"; }
$filename = $prefix.date(Ymd_His). create_check_ code(6).".sql"; // 保存在服务器上的文件名
// 注意后面的create_check_code()函数,这是一个生成随机码的函数,详细可以参考:
// aspx">http://blog.csdn.net/heiyeshuwu/archive/2005/01/26/268446.aspx
// 获取数据库结构和数据内容
foreach($tables as $table)
{
if ($back_mode == all) { $sqldump .= data2sql($table); }
if ($back_mode == table) { $sqldump .= table2sql($table); }
}
// 如果数据内容不是空就开始保存
if(trim($sqldump))
{
// 写入开头信息
$sqldump =
"# -------------------------------------------------------- ".
"# 数据表备份 ".
"# ".
"# 服务器: $db->Host ".
"# 数据库:$db->Database ".
"# 备份编号: ". create_sess_id() ." ". // 这里有一个生成session id的函数
"# 备份时间: ".time_to_date(,6)." ". // 这里就是获取当前时间的函数
"# ".
"# 管理员:$admin ($admin_email) ". // 管理员的用户名和邮箱地址
"# $copyright ".
"# -------------------------------------------------------- ".
$sqldump;
// 保存到本地
if($saveto == "local")
{
ob_end_clean();
header(Content-Encoding: none);
header(Content-Type: .(strpos($HTTP_SERVER_VARS[HTTP_USER_AGENT], MSIE) ? application/octetstream : application/octet-stream));
header(Content-Disposition: .(strpos($HTTP_SERVER_VARS[HTTP_USER_AGENT], MSIE) ? inline; : attachment; ).filename=".$local_filename);
header(Content-Length: .strlen($sqldump));
header(Pragma: no-cache);
header(Expires: 0);
echo $sqldump;
}
// 保存到本地结束
// 保存在服务器
if($saveto == "server")
{
if($filename != "")
{
@$fp = fopen($filename, "w+");
if ($fp)
{
@flock($fp, 3);
if(@!fwrite($fp, $sqldump))
{
@fclose($fp);
exit_msg("数据文件无法保存到服务器,请检查目录属性你是否有写的权限。");
}
else
{
exit_msg("数据成功备份至服务器 $filename 中。");
}
}
else
{
exit_msg("无法打开你指定的目录". $filename .",请确定该目录是否存在,或者是否有相应权限");
}
}
else
{
exit_msg("您没有输入备份文件名,请返回修改。");
}
}
// 保存到服务器结束
}
else
{
exit_msg("数据表没有任何内容");
}
/* 备份数据库结束 */
呵呵,基本上这样就结束了,然后涉及到的一个问题是如何把数据恢复到数据库中,我想这个是不复杂的,但是最好能够满足有从客户端和从服务器恢复数据的功能。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

在開發一個小型應用時,我遇到了一個棘手的問題:需要快速集成一個輕量級的數據庫操作庫。嘗試了多個庫後,我發現它們要么功能過多,要么兼容性不佳。最終,我找到了minii/db,這是一個基於Yii2的簡化版本,完美地解決了我的問題。

Oracle不僅是數據庫公司,還是雲計算和ERP系統的領導者。 1.Oracle提供從數據庫到雲服務和ERP系統的全面解決方案。 2.OracleCloud挑戰AWS和Azure,提供IaaS、PaaS和SaaS服務。 3.Oracle的ERP系統如E-BusinessSuite和FusionApplications幫助企業優化運營。

文章摘要:本文提供了詳細分步說明,指導讀者如何輕鬆安裝 Laravel 框架。 Laravel 是一個功能強大的 PHP 框架,它 упростил 和加快了 web 應用程序的開發過程。本教程涵蓋了從系統要求到配置數據庫和設置路由等各個方面的安裝過程。通過遵循這些步驟,讀者可以快速高效地為他們的 Laravel 項目打下堅實的基礎。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

PHP仍然流行的原因是其易用性、靈活性和強大的生態系統。 1)易用性和簡單語法使其成為初學者的首選。 2)與web開發緊密結合,處理HTTP請求和數據庫交互出色。 3)龐大的生態系統提供了豐富的工具和庫。 4)活躍的社區和開源性質使其適應新需求和技術趨勢。
