php中实现xml与mysql数据相互转换的方法
2014-12-25 00:00
796 查看
本文实例讲述了php中实现xml与mysql数据相互转换的方法。分享给大家供大家参考。具体分析如下:
这里提供了一个mysql2xml转换类,可以快速的把xml转换成mysql同时反之也可以把mysql转换成xml,下面看代码.
mysql2xml.php类文件,用于备份MySQL数据的,代码如下:
调用方法,代码如下:
希望本文所述对大家的php程序设计有所帮助。
这里提供了一个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程序设计有所帮助。
相关文章推荐
- php中实现xml与mysql数据相互转换的方法
- php实现二进制和文本相互转换的方法
- php实现阿拉伯数字和罗马数字相互转换的方法
- PHP实现数组array转换成xml的方法
- PHP实现数组array转换成xml的方法
- 用php实现xml与json之间的相互转换
- PHP实现ASCII码与字符串相互转换的方法
- php实现将数组转换为XML的方法
- PHP实现Unicode编码相互转换的方法示例
- XML和MYSQL转换--PHP实现
- php+mysqli预处理技术实现添加、修改及删除多条数据的方法
- 报错:对象必须实现 IConvertible;以分隔符进行分割链接concat_ws的使用方法;mysql数据类型转换cast,convert
- C#实现XML与实体类之间相互转换的方法(序列化与反序列化)
- php实现将数组转换为XML的方法
- php实现xml与json之间的相互转换功能实例
- [MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)
- [MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)
- PHP实现XML与数据格式进行转换类实例
- php基于Fleaphp框架实现cvs数据导入MySQL的方法
- php+mysqli实现批量执行插入、更新及删除数据的方法