php 导出.sql文件/mysql数据库备份程序_PHP教程
$database='';//数据库名
$options=array(
'hostname' => '',//ip地址
'charset' => 'utf8',//编码
'filename' => $database.'.sql',//文件名
'username' => '',
'password' => ''
);
mysql_connect($options['hostname'],$options['username'],$options['password'])or die("不能连接数据库!");
mysql_select_db($database) or die("数据库名称错误!");
mysql_query("SET NAMES '{$options['charset']}'");
$tables = list_tables($database);
$filename = sprintf($options['filename'],$database);
$fp = fopen($filename, 'w');
foreach ($tables as $table) {
dump_table($table, $fp);
}
fclose($fp);
//下载sql文件
$file_name=$options['filename'];
Header("Content-type:application/octet-stream");
Header("Content-Disposition:attachment;filename=".$file_name);
readfile($file_name);
//删除服务器上的sql文件
unlink($file_name);
exit;
//获取表的名称
function list_tables($database)
{
$rs = mysql_list_tables($database);
$tables = array();
while ($row = mysql_fetch_row($rs)) {
$tables[] = $row[0];
}
mysql_free_result($rs);
return $tables;
}
//导出数据库
function dump_table($table, $fp = null)
{
$need_close = false;
if (is_null($fp)) {
$fp = fopen($table . '.sql', 'w');
$need_close = true;
}
$a=mysql_query("show create table `{$table}`");
$row=mysql_fetch_assoc($a);fwrite($fp,$row['Create Table'].';');//导出表结构
$rs = mysql_query("SELECT * FROM `{$table}`");
while ($row = mysql_fetch_row($rs)) {
fwrite($fp, get_insert_sql($table, $row));
}
mysql_free_result($rs);
if ($need_close) {
fclose($fp);
}
}
//导出表数据
function get_insert_sql($table, $row)
{
$sql = "INSERT INTO `{$table}` VALUES (";
$values = array();
foreach ($row as $value) {
$values[] = "'" . mysql_real_escape_string($value) . "'";
}
$sql .= implode(', ', $values) . ");";
return $sql;
}?>
推荐阅读
-
php将mysql数据库整库导出生成sql文件的具体实现
-
备份mysql数据库的php代码(一个表一个文件)
-
PHP实现把MySQL数据库导出为.sql文件实例(仿PHPMyadmin导出功能)
-
PHP备份数据库生成SQL文件并下载的函数代码
-
php使用指定编码导出mysql数据到csv文件的方法_PHP教程
-
php 备份数据库代码(生成word,excel,json,xml,sql)_PHP教程
-
MySQL数据库转移,access,sql server 转 MySQL 的图文教程_php技巧
-
怎样将MySQL数据库结构和数据导出或导入_PHP教程
-
php实现备份mysql数据库_PHP教程
-
php连接mysql数据库连接测试文件_PHP教程