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