首頁  >  文章  >  後端開發  >  vb連接sql資料庫 備份mysql資料庫的php程式碼一個表一個文件

vb連接sql資料庫 備份mysql資料庫的php程式碼一個表一個文件

WBOY
WBOY原創
2016-07-29 08:42:541155瀏覽

複製程式碼 程式碼如下:


$cfg_dbhost ='localhost';//my主機$cfg_dbhost ='localhost';//my主機$cfg_dbhost ='localhost';//my主機
主機
主機$cfg_dbuser ='root';//資料庫使用者名稱
$cfg_dbpwd ='jb51.net';//資料庫使用者密碼
$cfg_db_language ='utf8 ';//資料庫編碼
class dbmysql{
public static $dbhost = 'localhost';
public static $dbname;
public static $dbuser = 'root';
public static $ dbpass;
public static $charset = 'utf8';
public static $DB = null;
public $querycount = 0;
public function __construct()
{
self: :$dbhost = $GLOBALS['cfg_dbhost'];
self::$dbname = $GLOBALS['cfg_dbname'];
self::$dbuser = $GLOBALS['cfg_dbuser'];
self ::$dbpass = $GLOBALS['cfg_dbpwd'];
self::$charset= $GLOBALS['cfg_db_language'];
self::connect();
}
public function connect (){
self::$DB=mysql_connect(self::$dbhost,self::$dbuser,self::$dbpass);
if(!self::$DB){
self ::sqlError('無法連接伺服器!'.self::mysqlerror);exit("無法連接伺服器!");;
}
if(!mysql_select_db(self::$dbname)){
self::sqlError('無法連接資料庫('.self::$dbname.')!'.self::mysqlerror);exit("無法連接資料庫!");
}
mysql_query(" SET NAMES '".self::$charset."', character_set_client=binary, sql_mode='';",self::$DB);
}
private function mysqlerror(){
return mysql_error ();
}
public function getTablesName(){
$res = mysql_query('SHOW TABLES FROM '.self::$dbname,self::$DB);
$tables=array ();
while ($row=mysql_fetch_row($res))$tables[]=$row[0];
mysql_free_result($res);
return $tables;
}
public function getFields($table){
$res=mysql_query('DESCRIBE '.$table,self::$DB);
$tables=array();
while($row=mysql_fetch_row ($res))$tables[]=$row[0];
mysql_free_result($res);
return $tables;
}
public function fetch_array($sql){
$res=mysql_query($sql,self::$DB);
$r=mysql_fetch_array($res);
mysql_free_result($res);
return $r;
}
public function fetch_assoc($sql){
$q3=mysql_query($sql,self::$DB); $ra=array();
while($data=mysql_fetch_assoc($q3)){
$ra[]=$data;
}
mysql_free_result($q3);
return $ra;
}
private function sqlError($message='',$info =' ',$sql=''){//儲存錯誤訊息到檔案
echo "{".$message."
DATE: ".date('Y-n-j H:i:s')."ERROR: ".$info."
SQL: ".$sql."
}
";
}
public function close(){
self::$DB =null;
}
public function __destruct()
{
self::close();
}
}
/*--- class end*/
function makedir($dirpath){
if(!$dirpath) return 0;
$dirpath=str_replace("\","/",$dirpath); $mdir=" ";
foreach(explode("/",$dirpath) as $val){
$mdir.=$val."/";
if($val==".."|| $val==".")continue;
if(!is_dir($mdir)&&!file_exists($mdir)){
if(!@mkdir($mdir,0755)){
exit ("建立目錄[".$mdir."]失敗.");
}
}
}
return true;
}
function delDirAndFile($dirName){
if($handle=opendir($dirName)){
while(false!==($item = readdir($handle))){
if($item !="."&&$item !=".."){
if(is_dir( "$dirName/$item")){
delDirAndFile( "$dirName/$item");
}else{ unlink("$dirName /$item"); }
}
}
closedir( $handle );
if( rmdir( $dirName ) )echo "成功刪除目錄: $dirName
n";
}
}
function filein($filename="databak/",$table='',$mysql=''){
$fp = fopen($filename.'/'. $table.'.sql','w');
fputs($fp,$mysql);
fclose($fp);
}
header("Content-Type:text/ html;charset=utf-8");
$db=new dbmysql();
$table=$db->getTablesName();
$filename="databak/".date("Ymd ");
$url=getcwd()."/databak/";
$handle = opendir($url);
while(false!==($file = readdir($handle)) ){
if ($file!="."&&$file!=".."&&is_dir($url."/".$file)) {
if(date("Ymd")-$ file>5){delDirAndFile($url."/".$file);};
}
}
makedir($filename);
foreach($table as $t){
$s1=$db->fetch_array("show create table `$t`");
$mysql="/*Time:".date("Y-m-d H:i:s")." */ rnDROP TABLE IF EXISTS `$t`;rn".$s1['Create Table'].";rnrn";
$a1=$db->fetch_assoc("select * from `$t`");
foreach ($a1 as $data){
$vals=array_values($data);
$vals=array_map('addslashes',$vals);
$vals=join("', '",$vals);
$vals="'".$vals."'";
$mysql.="INSERT INTO `$t` VALUES ($vals);rn";
}
$mysql.="rn";
filein($filename,$t,$mysql);
}

echo "資料備份成功,產生備份檔案".getcwd()." /".$filename."/
程式自動清理5天以前的備份";

?>

以上就介紹了vb連接sql資料庫 備份mysql資料庫的php程式碼一個表一個文件,包括了vb連接sql資料庫方面的內容,希望對PHP教程有興趣的朋友有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn