国产探花免费观看_亚洲丰满少妇自慰呻吟_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程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 卓尼县| 新和县| 阳信县| 绵竹市| 大同县| 杨浦区| 凉城县| 白朗县| 将乐县| 南丹县| 黔江区| 瑞安市| 宁波市| 晋城| 南和县| 海兴县| 靖西县| 洪泽县| 彭水| 丹棱县| 灌南县| 仁怀市| 辽宁省| 宁乡县| 青河县| 田林县| 澄江县| 霍林郭勒市| 无极县| 开鲁县| 鄂托克旗| 江陵县| 确山县| 许昌市| 忻州市| 彭山县| 白朗县| 施甸县| 景洪市| 象州县| 丹江口市|