本文实例讲述了php中实现xml与mysql数据相互转换的方法。分享给大家供大家参考。具体分析如下:
这里提供了一个mysql2xml转换类,可以快速的把xml转换成mysql同时反之也可以把mysql转换成xml,下面看代码.
mysql2xml.php类文件,用于备份MySQL数据的,代码如下:
复制代码 代码如下:<"\", "/", $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 = "<"1.0" encoding="utf-8" "; 
                $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; 
        } 
} 
"codetitle">复制代码 代码如下:<?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程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?