国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php中實現xml與mysql數據相互轉換的方法

2024-05-04 23:29:25
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了php中實現xml與mysql數據相互轉換的方法,實例封裝了一個類文件,可實現XML與MySQL數據的相互轉換,具有一定的參考借鑒價值,需要的朋友可以參考下
 
 

本文實例講述了php中實現xml與mysql數據相互轉換的方法。分享給大家供大家參考。具體分析如下:

這里提供了一個mysql2xml轉換類,可以快速的把xml轉換成mysql同時反之也可以把mysql轉換成xml,下面看代碼.

mysql2xml.php類文件,用于備份MySQL數據的,代碼如下:

復制代碼代碼如下:
<?php 
class MySQL2XML { 
        protected $conn; 
        protected $result; 
        protected $tables; 
        protected $saveFolder = 'datas/'; 
         
        public function __construct($config = NULL) { 
                if($config !== NULL && is_array($config)) { 
                        $this->connect($config); 
                } 
        } 
         
        public function connect($config) { 
                $this->conn = mysql_connect($config['host'], $config['username'], $config['password']); 
                if($this->conn) { 
                        mysql_select_db($config['database']); 
                        return true; 
                } 
                return false; 
        } 
         
        public function setSaveFolder($folder) { 
                if(is_dir($folder)) { 
                        $this->saveFolder = rtrim(str_replace("/", "/", $folder),'/'); 
                        return true; 
                } 
                return false; 
        } 
         
        public function setTables($tables) { 
                if(is_array($tables)) { 
                        $this->tables = $tables; 
                        return true; 
                } 
                return false; 
        } 
         
        public function query($query) { 
                if(!isset($query) || trim($query) == '') return false; 
                $this->result = mysql_query($query); 
                if($this->result) return true; 
                return false; 
        } 
         
        public function toXML() { 
                if(!isset($this->tables)) return false; 
                foreach($this->tables as $table) { 
                        $file = $this->saveFolder.$table.'.xml'; 
                        $fp = @fopen($file, 'w'); 
                        if(!$fp) exit('Can not write file'); 
                        fwrite($fp, $this->tableToXML($table)); 
                        fclose($fp); 
                        unset($fp); 
                } 
                return true; 
        } 
         
        public function tableToXML($table) { 
                header("content-type:text/xml;charset=utf-8"); 
                $xml = "<?xml version="1.0" encoding="utf-8" ?>n<datas>n"; 
                $fields = $this->getFields($table); 
                $datas = $this->getDatas($table); 
                $cdata = array(); 
                foreach($datas as $data) { 
                        foreach($data as $key => $value) 
                                $cdata[$key][] = $value; 
                } 
                foreach($fields as $element) { 
                        $xml .= "t<fields name="{$element['Field']}" type="{$element['Type']}" null="{$element['Null']}" key="{$element['Key']}" default="{$element['Default']}" extra="{$element['Extra']}">n"; 
                        foreach($cdata[$element['Field']] as $value) { 
                                $xml .= "tt<data>{$value}</data>n"; 
                        } 
                        $xml .= "t</fields>n"; 
                } 
                $xml .= '</datas>'; 
                return $xml; 
        } 
         
        protected function getFields($table) { 
                $query = "SHOW FIELDS FROM {$table}"; 
                $this->query($query); 
                return $this->fetchAll(); 
        }
         
        protected function getDatas($table) { 
                $query = "SELECT * FROM {$table}"; 
                $this->query($query); 
                return $this->fetchAll(); 
        } 
         
        protected function fetch() { 
                if(is_resource($this->result)) { 
                        return mysql_fetch_assoc($this->result); 
                } 
                return false; 
        } 
         
        protected function fetchAll() { 
                if(is_resource($this->result)) { 
                        $return = array(); 
                        $row = NULL; 
                        while($row = mysql_fetch_assoc($this->result)) { 
                                $return[] = $row; 
                        } 
                        return $return; 
                } 
                return false; 
        } 

?>

調用方法,代碼如下:
復制代碼代碼如下:
<?php 
$xml = new MySQL2XML(array('host'=>'localhost', 'username'=>'root', 'password'=>'', 'database'=>'mysql')); 
$xml->setTables(array('wp_term_relationships','wp_terms'));//設置備份的表 
$xml->setSaveFolder('datas/');//保存備份文件的文件夾 
$xml->toXML();//備份開始 
?>

 

希望本文所述對大家的php程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宾阳县| 施秉县| 阳曲县| 肥东县| 赣榆县| 南雄市| 高台县| 突泉县| 扬中市| 那坡县| 慈利县| 辽源市| 婺源县| 孝昌县| 万年县| 新和县| 贵州省| 青阳县| 泾源县| 堆龙德庆县| 广州市| 荃湾区| 宿州市| 彭泽县| 自贡市| 阿坝| 衡水市| 竹溪县| 苏尼特右旗| 花垣县| 贞丰县| 临泉县| 青铜峡市| 杭锦旗| 长岭县| 肇州县| 雅江县| 边坝县| 阿勒泰市| 察隅县| 南岸区|