php实现解析xml并生成sql语句的方法

2018-09-07 12:04

阅读:472

  本文实例讲述了php实现解析xml并生成sql语句的方法。分享给大家供大家参考,具体如下:

  php解析xml有很多种办法,文档中有,搜索一下就一大把的。

  今天遇到一个需求:将某个xml中的节点属性提取出来,然后更新数据库某一表中的字段。

  思路:

  解析XML,获取所有的节点属性 –> 循环节点集合,获取对应的属性 –> 拼接sql字符串存入一数组 –> 将数组转为字符串保存于某一文件中

  这里使用了xpath,在写代码的过程中遇到两个问题:

  1、xml的史路径属性为D:\xx\…时load不了文件,改为”/”(linux下的分隔符)就可以了

  2、获取一个节点的属性,使用::attributes,编辑器就不停的红色提示,找到半天文档,最后用->getAttribute()就行了(猜的,因为太奇怪了,它支持->previousSibling和->nodeValue),按照,文档上的DOMElement::getAttribute直接就报错了..

  下面是示例代码:

   <title>xml 转换为 sql</title> <meta http-equiv=content-type content=text/html; charset=utf-8 /> <style type=text/css> .tip_info {margin-bottom:10px;} .tip_info span {color:#f00;} </style> <?php $xml = D:/res/dressConfig.xml; $doc = new DOMDocument(); $doc->load($xml); $xpath = new DOMXPath($doc); $query = //i; $entries = $xpath->query($query); $len = $entries->length; echo <div class=tip_info>总共找到:<span>.$len.</span>个节点</div>; $arr = array(); $idx = 0; while ($idx < $len) { $nodeItem = $entries->item($idx); $id = $nodeItem->getAttribute(i); $name = $nodeItem->getAttribute(n); $inf = $nodeItem->getAttribute(inf); // echo <div>.$id.--.$name.--.$inf.</div>; $idx++; array_push($arr, update dress_item t SET t.s_name=.$name.,t.s_intro=.$inf. WHERE t.n_doid=.$id.;); } $dir = d:/sql/; if (!is_dir($dir)) { mkdir($dir); } file_put_contents(d:/sql/dress_item.sql, implode(\n\r, $arr)); echo 生成完毕!; ?>

  因为数据是从数据库表中生成出来的,所以找到的节点数即为表中的记录总数。生成后可以大概看一下内容是否正确,然后再执行该sql脚本便达到目的了。

  PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

  在线XML/JSON互相转换工具:

  在线格式化XML/在线压缩XML:

  XML在线压缩/格式化工具:

  XML代码在线格式化美化工具:

  更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP针对XML文件操作技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP错误与异常处理方法总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

  希望本文所述对大家PHP程序设计有所帮助。


评论


亲,登录后才可以留言!