<?php
/**
转自:http://yanue.net/post-19.html
修改:265行,将mysql_escape_string改为mysql_real_escape_string,PHP5.3以后已经淘汰mysql_escape_string。
*/
class DbManage {
var $db; // 数据库连接
var $database; // 所用数据库
var $sqldir; // 数据库备份文件夹
var $msg; // 提示信息
var $file; // 备份成功保存文件名
// 换行符
private $ds = "\n";
// 存储SQL的变量
public $sqlContent = "";
// 每条sql语句的结尾符
public $sqlEnd = ";";
/**
* 初始化
*
* @param string $host
* @param string $username
* @param string $password
* @param string $database
* @param string $charset
*/
function __construct($host = 'localhost', $username = 'root', $password = '', $database = 'test', $charset = 'utf8') {
$this->host = $host;
$this->username = $username;
$this->password = $password;
$this->database = $database;
$this->charset = $charset;
set_time_limit(0);//无时间限制
@ob_end_flush();
// 连接数据库
$this->db = @mysql_connect ( $this->host, $this->username, $this->password ) or die( '<p class="dbDebug"><span class="err">Mysql Connect Error : </span>'.mysql_error().'</p>');
// 选择使用哪个数据库
mysql_select_db ( $this->database, $this->db ) or die('<p class="dbDebug"><span class="err">Mysql Connect Error:</span>'.mysql_error().'</p>');
// 数据库编码方式
mysql_query ( 'SET NAMES ' . $this->charset, $this->db );
}
/*
* 新增查询数据库表
*/
function getTables() {
$res = mysql_query ( "SHOW TABLES" );
$tables = array ();
while ( $row = mysql_fetch_array ( $res ) ) {
$tables [] = $row [0];
}
return $tables;
}
/*
*
* ------------------------------------------数据库备份start----------------------------------------------------------
*/
/**
* 数据库备份
* 参数:备份哪个表(可选),备份目录(可选,默认为backup),分卷大小(可选,默认2000,即2M)
*
* @param $string $dir
* @param int $size
* @param $string $tablename
*/
function backup($tablename = '', $dir, $size) {
$dir = $dir ? $dir : './backup/';
// 创建目录
if (! is_dir ( $dir )) {
mkdir ( $dir, 0777, true ) or die ( '创建文件夹失败' );
}
$size = $size ? $size : 2048;
$sql = '';
// 只备份某个表
if (! empty ( $tablename )) {
if(@mysql_num_rows(mysql_query("SHOW TABLES LIKE '".$tablename."'")) == 1) {
} else {
$this->_showMsg('表-<b>' . $tablename .'</b>-不存在,请检查!',true);
die();
}
$this->_showMsg('正在备份表 <span class="imp">' . $tablename.'</span>');
// 插入dump信息
$sql = $this->_retrieve ();
// 插入表结构信息
$sql .= $this->_insert_table_structure ( $tablename );
// 插入数据
$data = mysql_query ( "select * from " . $tablename );
// 文件名前面部分
$filename = date ( 'YmdHis' ) . "_" . $tablename;
// 字段数量
$num_fields = mysql_num_fields ( $data );
// 第几分卷
$p = 1;
// 循环每条记录
while ( $record = mysql_fetch_array ( $data ) ) {
// 单条记录
$sql .= $this->_insert_record ( $tablename, $num_fields, $record );
// 如果大于分卷大小,则写入文件
if (strlen ( $sql ) >= $size * 1024) {
$file = $filename . "_v" . $p . ".sql";
$this -> file = $file;
if ($this->_write_file ( $sql, $file, $dir )) {
$this->_showMsg("表-<b>" . $tablename . "</b>-卷-<b>" . $p . "</b>-数据备份完成,备份文件 [ <span class='imp'>" .$dir . $file ."</span> ]");
} else {
$this->_showMsg("备份表 -<b>" . $tablename . "</b>- 失败",true);
return false;
}
// 下一个分卷
$p ++;
// 重置$sql变量为空,重新计算该变量大小
$sql = "";
}
}
// 及时清除数据
unset($data,$record);
// sql大小不够分卷大小
if ($sql != "") {
$filename .= "_v" . $p . ".sql";
$this -> file = $filename;
if ($this->_write_file ( $sql, $filename, $dir )) {
$this->_showMsg( "表-<b>" . $tablename . "</b>-卷-<b>" . $p . "</b>-数据备份完成,备份文件 [ <span class='imp'>" .$dir . $filename ."</span> ]");
} else {
$this->_showMsg("备份卷-<b>" . $p . "</b>-失败<br />");
return false;
}
}
$this->_showMsg("恭喜您! <span class='imp'>备份成功</span>");
return true;
} else {
$this->_showMsg('正在备份');
// 备份全部表
if ($tables = mysql_query ( "show table status from " . $this->database )) {
$this->_showMsg("读取数据库结构成功!");
} else {
$this->_showMsg("读取数据库结构失败!");
exit ( 0 );
}
// 插入dump信息
$sql .= $this->_retrieve ();
// 文件名前面部分
$filename = date ( 'YmdHis' ) . "_all";
// 查出所有表
$tables = mysql_query ( 'SHOW TABLES' );
// 第几分卷
$p = 1;
// 循环所有表
while ( $table = mysql_fetch_array ( $tables ) ) {
// 获取表名
$tablename = $table [0];
// 获取表结构
$sql .= $this->_insert_table_structure ( $tablename );
$data = mysql_query ( "select * from " . $tablename );
$num_fields = mysql_num_fields ( $data );
// 循环每条记录
while ( $record = mysql_fetch_array ( $data ) ) {
// 单条记录
$sql .= $this->_insert_record ( $tablename, $num_fields, $record );
// 如果大于分卷大小,则写入文件
if (strlen ( $sql ) >= $size * 1000) {
$file = $filename . "_v" . $p . ".sql";
$this -> file = $file;
// 写入文件
if ($this->_write_file ( $sql, $file, $dir )) {
$this->_showMsg("-卷-<b>" . $p . "</b>-数据备份完成,备份文件 [ <span class='imp'>".$dir.$file."</span> ]");
} else {
PHP备份或导入mysql数据库类(含有demo,亲测可用)
需积分: 10 117 浏览量
2018-05-07
10:47:33
上传
评论
收藏 65KB ZIP 举报
追风2019
- 粉丝: 51
- 资源: 6
最新资源
- 111111111111111111
- 咪视界.apk
- C语言期末大作业之实现成语连连看.zip
- C语言期末大作业之实现扫雷游戏.zip
- C语言期末大作业之图书信息管理系统实现-基于Dev-C++实现.zip
- tensorflow-rocm-2.13.1.600-cp39-cp39-manylinux2014-x86-64.whl
- tensorflow-gpu-2.7.0-cp39-cp39-manylinux2010-x86-64.whl
- C语言期末大作业之图书信息管理系统实现-基于VivualStudio实现.zip
- tensorflow-gpu-2.7.0-cp38-cp38-manylinux2010-x86-64.whl
- 电子科大 电路分析与模拟电路 实验报告.pdf
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈