2006년 1월 15일 일요일

php로 DB 백업하기

<?
$mysql_host = "localhost"; // 호스트정보
$mysql_db = ""; // 백업할 DB명
$mysql_user = ""; // 사용자 아이디
$mysql_pass = ""; // 사용자 비번



$fileName = date("Y_m_d_H_i"); //백업받을 파일명
$extention = "sql"; // 백업 받을 파일 확장자



$all = false; //완전한 Insert 문을 작성하려면 true
$drop = false; //drop table 구문을 포함하려면 true



mysql_connect( $mysql_host, $mysql_user, $mysql_pass ) || die("데이타 베이스 접속에 실패하였습니다.");
mysql_select_db( $mysql_db ) || die("DB 접속 실패");



function bak_getTableNames($db) {
$result[0] = mysql_list_tables($db);
$result[1] = mysql_num_rows($result[0]);
return $result;
}



function bak_getFields($table) {
global $all;
$result = mysql_query("show fields from $table");
$i = 0;
while($keys = mysql_fetch_array($result)) {
if(!$i) $defaultOrder = $keys[Field];
if($keys[Key] == 'PRI') {
$orderby = $keys[Field];
break;
}
$i++;
}
if(!$orderby) $orderby = $defaultOrder;
$result = mysql_query("select * from $table order by $orderby");
$nums = mysql_num_fields($result);
if($all == true) {
for($i=0;$i<$nums;$i++) {
$fields[] = mysql_field_name($result,$i);
}
$fields = "(".implode(",",$fields).") ";
}
while($rows = mysql_fetch_row($result)) {
for($i=0;$i<$nums;$i++) {
$insertValues[$i] = $rows[$i];
}
$return .= "INSERT INTO $table ".$fields."values ('".implode("','",$insertValues)."');\n";
}
return $return;
}



$tables = bak_getTableNames($mysql_db);
if($tables[1] > 0) {
$backText = "
# MysqlDump
# 호스트: "
.$mysql_host."
# 처리한 시간: "
.date('Y년 n월 j일 H시 i분')."
# 서버 버전: "
.mysql_get_server_info()."
# 데이터베이스 : `"
.$mysql_db."`
# --------------------------------------------------------\n\n\n\n\n"
;
while($rows = mysql_fetch_row($tables[0])) {
$backText .= "
#
# 테이블 구조 `"
.$rows[0]."`
#\n\n"
;
$skima = mysql_fetch_array(mysql_query("SHOW CREATE TABLE ".$mysql_db.".".$rows[0]));
if($drop == true) $backText .= "DROP TABLE IF EXISTS ".$skima[0].";\n\n";
$backText .= "CREATE TABLE if not exists ".$skima[0]." ";
$pos = strpos($skima[1]," (");
$backText .= str_replace("`","",substr($skima[1],($pos+1))).";";



$insert = bak_getFields($rows[0]);
$backText .= "
#
# 테이블 '"
.$rows[0]."' insert 문
#"
;
if($insert) $backText .= "\n\n\n".$insert;
$backText .= "\n\n\n\n\n";
}



header("Content-Type: application/octetstream");
header("Content-Disposition: attachment; filename=".$fileName.".".$extention);
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
echo $backText;
}
?>

댓글 없음:

댓글 쓰기