php备份数据库类分享
2015-04-14 11:14
603 查看
php备份数据库类分享
<?php /** * * @name php备份数据库 * @param string $DbHost 连接主机 * @param string $DbUser 用户名 * @param string $DbPwd 连接密码 * @param string $DbName 要备份的数据库 * @param string $saveFileName 要保存的文件名, 默认文件保存在当前文件夹中,以日期作区分 * @return Null * @example backupMySqlData('localhost', 'root', '123456', 'YourDbName'); * */ function backupMySqlData($DbHost, $DbUser, $DbPwd, $DbName, $saveFileName = '') { header("Content-type:text/html;charset=utf-8"); error_reporting(0); set_time_limit(0); echo '数据备份中,请稍候......<br />'; $link = mysql_connect($DbHost, $DbUser, $DbPwd) or die('数据库连接失败: ' . mysql_error()); mysql_select_db($DbName) or die('数据库连接失败: ' . mysql_error()); mysql_query('set names utf8'); // 声明变量 $isDropInfo = ''; $insertSQL = ''; $row = array(); $tables = array(); $tableStructure = array(); $fileName = ($saveFileName ? $saveFileName : 'MySQL_data_bakeup_') . date('YmdHis') . '.sql'; // 枚举该数据库所有的表 $res = mysql_query("SHOW TABLES FROM $DbName"); while ($row = mysql_fetch_row($res)) { $tables[] = $row[0]; } mysql_free_result($res); // 枚举所有表的创建语句 foreach ($tables as $val) { $res = mysql_query("show create table $val", $link); $row = mysql_fetch_row($res); $isDropInfo = "DROP TABLE IF EXISTS `" . $val . "`;\r\n"; $tableStructure = $isDropInfo . $row[1] . ";\r\n"; file_put_contents($fileName, $tableStructure, FILE_APPEND); mysql_free_result($res); } // 枚举所有表的INSERT语句 foreach ($tables as $val) { $res = mysql_query("select * from $val"); // 没有数据的表不执行insert while ($row = mysql_fetch_row($res)) { $sqlStr = "INSERT INTO `".$val."` VALUES ("; foreach($row as $v){ $sqlStr .= "'$v',"; } //去掉最后一个逗号 $sqlStr = substr($sqlStr, 0, strlen($sqlStr) - 1); $sqlStr .= ");\r\n"; file_put_contents($fileName, $sqlStr, FILE_APPEND); } mysql_free_result($res); } echo '数据备份成功!'; } // 调用此方法 backupMySqlData('localhost', 'root', '123456', 'YouDbName'); ?>
以上所述就是本文的全部内容了,希望大家能够喜欢。
您可能感兴趣的文章:
相关文章推荐
- php备份数据库类分享
- php实例分享之mysql数据备份
- php实例分享之mysql数据备份
- php实例分享之mysql数据备份
- 定时备份脚本分享(网站数据和数据库数据)
- 分享elain.org 数据备份脚本
- PHP 导出数据到淘宝助手CSV的方法分享
- 有关于PHP中常见数据类型的汇总分享
- 【无私分享:从入门到精通ASP.NET MVC】从0开始,一起搭框架、做项目 (12)程序与数据备份
- php中模拟POST传递数据的两种方法分享
- PHP初学分享-数据类型
- php自动备份打包单个或多个数据表到txt的文本记事本中
- 分享一个千万数据的磁力搜索网站 bt书虫 php+mysql+nginx
- PHP网站备份程序代码分享
- 分享有关于PHP 数据类型的汇总
- 使用PHP备份MYSQL数据的多种方法
- 定时备份脚本分享(网站数据和数据库数据)
- Allway Sync--同步备份数据资料,简单介绍及使用经验分享
- 数据丢失不用怕 iPhone手机数据备份方法分享