100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > php mysql备份成sql_单php文件实现备份MySQL导出为.sql数据库代码

php mysql备份成sql_单php文件实现备份MySQL导出为.sql数据库代码

时间:2022-02-13 07:17:23

相关推荐

php mysql备份成sql_单php文件实现备份MySQL导出为.sql数据库代码

最近处理一个客户的站点,对方主机商给的权限太小,建立目录都不能,也没办法上传帝国备份网备份,后台备份也可以,但是确实也很麻烦,有没有快的办法呢,其实客户那里可以上传单文件,这不写一个单文件代码,自动生成就可以了嘛,操作如下:

单文件可实现mysql数据库备份,且生成.sql后缀;无需登录phpMyAdmin等软件在导出数据;

代码如下:

// 备份数据库

$T_Host = "localhost"; //数据库地址

$user = ""; //数据库账号

$password = ""; //数据库密码

$dbname = ""; //数据库名称

// 这里的账号、密码、名称都是从页面传过来的

if (!mysql_connect($T_Host, $user, $password)) // 连接mysql数据库

{

echo '数据库连接失败,请核对后再试';

exit;

}

if (!mysql_select_db($dbname)) // 是否存在该数据库

{

echo '不存在数据库:' . $dbname . ',请核对后再试';

exit;

}

mysql_query("set names 'utf8'");

$mysql = "set charset utf8;\r\n";

$q1 = mysql_query("show tables");

while ($t = mysql_fetch_array($q1))

{

$table = $t[0];

$q2 = mysql_query("show create table `$table`");

$sql = mysql_fetch_array($q2);

$mysql .= $sql['Create Table'] . ";\r\n";

$q3 = mysql_query("select * from `$table`");

while ($data = mysql_fetch_assoc($q3))

{

$keys = array_keys($data);

$keys = array_map('addslashes', $keys);

$keys = join('`,`', $keys);

$keys = "`" . $keys . "`";

$vals = array_values($data);

$vals = array_map('addslashes', $vals);

$vals = join("','", $vals);

$vals = "'" . $vals . "'";

$mysql .= "insert into `$table`($keys) values($vals);\r\n";

}

}

//存放路径,默认存放到该文件所在目录

$filename = $dbname . date('Ymjgi') . ".sql"; //文件命名

$fp = fopen($filename, 'w'); //以写入方式打开文件,文件不存在则创建

fputs($fp, $mysql); //写入内容

fclose($fp); //关闭一个打开文件

echo "数据备份成功";

?>

所写所说,是心之所感,思之所悟,行之所得;文当无敷衍,落笔求简洁。 以所舍,求所获;有所依,方所成!(有事儿请详询博主:博主电话以及微信18810292089)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。