oracle解析xml完成版

SELECT * FROM XMLTABLE(‘$B/DEAL_BASIC/USER_DEAL_INFO‘ PASSING
XMLTYPE(‘<?xml version="1.0" encoding="gb2312" ?>&xml‘) AS B
COLUMNS USER_DEAL_ID VARCHAR2(50) PATH
‘/USER_DEAL_INFO/USER_DEAL_ID‘,
DEAL_INURE_TIME VARCHAR2(50) PATH
‘/USER_DEAL_INFO/DEAL_INURE_TIME‘,
DEAL_EXPIRE_TIME VARCHAR2(50) PATH
‘/USER_DEAL_INFO/DEAL_EXPIRE_TIME‘,
DEAL_CREATE_TIME VARCHAR2(50) PATH
‘/USER_DEAL_INFO/DEAL_CREATE_TIME‘);

<DEAL_BASIC>
<USER_DEAL_INFO>
<USER_DEAL_ID>1000100001</USER_DEAL_ID>
<DEAL_INURE_TIME>20081130</DEAL_INURE_TIME>
<DEAL_EXPIRE_TIME>30000101</DEAL_EXPIRE_TIME>
<DEAL_CREATE_TIME>20081130</DEAL_CREATE_TIME>
</USER_DEAL_INFO>
</DEAL_BASIC>
--------------------------------------------------------
--案例一 完成的

SELECT * FROM XMLTABLE(‘$B/ROW‘ PASSING
XMLTYPE(‘<?xml version="1.0" encoding="gb2312" ?>&xml‘) AS B
COLUMNS
TP_ID VARCHAR2(50) PATH
‘/ROW/TP_ID‘,
TP_NAME VARCHAR2(50) PATH
‘/ROW/TP_NAME‘,
TP_PARENTID VARCHAR2(50) PATH
‘/ROW/TP_PARENTID‘,
TP_SNAME VARCHAR2(50) PATH
‘/ROW/TP_SNAME‘);

<ROW>
<TP_ID>112</TP_ID>
<TP_NAME>oracle</TP_NAME>
<TP_PARENTID>0</TP_PARENTID>
<TP_SNAME>R</TP_SNAME>
</ROW>
----------------------------------------------------------------------
--案例二 单引号 不能识别

SELECT * FROM XMLTABLE(‘$B/DEAL_BASIC/USER_DEAL_INFO‘ PASSING
XMLTYPE(‘<?xml version="1.0" encoding="gb2312" ?>&xml‘) AS B
COLUMNS USER_DEAL_ID VARCHAR2(50) PATH
‘/USER_DEAL_INFO/ROW_ID‘,
DEAL_INURE_TIME VARCHAR2(50) PATH
‘/USER_DEAL_INFO/ROW_TIME‘,
DEAL_EXPIRE_TIME VARCHAR2(50) PATH
‘/USER_DEAL_INFO/ROW_NAME‘);

<DEAL_BASIC>

<USER_DEAL_INFO>
<ROW_ID>1000100001</ROW_ID>
<ROW_TIME>ORACLE</ROW_TIME>
<ROW_NAME>30000101</ROW_NAME>
</USER_DEAL_INFO>

<USER_DEAL_INFO>
<ROW_ID>1000100001</ROW_ID>
<ROW_TIME>ORACLE</ROW_TIME>
<ROW_NAME>30000101</ROW_NAME>
</USER_DEAL_INFO>

</DEAL_BASIC>
--------------------------------------------------------------------
--案例三 完成的
SELECT * FROM XMLTABLE(‘$B/orderlist/order‘ PASSING
XMLTYPE(‘<?xml version="1.0" encoding="gb2312" ?>&xml‘) AS B
COLUMNS orderid VARCHAR2(50) PATH
‘/order/orderid‘,
ordernumber VARCHAR2(50) PATH
‘/order/ordernumber‘,
orderpriceE VARCHAR2(50) PATH
‘/order/orderprice‘);

<orderlist>
<order>
<orderid>1</orderid>
<ordernumber>857544544</ordernumber>
<orderprice>54</orderprice>
</order>

<order>
<orderid>2</orderid>
<ordernumber>858544544</ordernumber>
<orderprice>63</orderprice>
</order>

<order>
<orderid>3</orderid>
<ordernumber>454854555</ordernumber>
<orderprice>781</orderprice>
</order>
</orderlist>

费了千辛万苦 ,终于有了一点门路

时间: 2024-07-30 08:03:00

oracle解析xml完成版的相关文章

oracle解析xml完成版第二次修改

其实XML字符串就好像是ORACLE中的外部表,因此Oracle对 解析XML字符串一些规则要求非常严格.XML字符串提供的数据就是一张表,所以Oracle必须提供跟 xml数据一致的列头 示例一 SELECT * FROM XMLTABLE('$B/DEAL_BASIC/USER_DEAL_INFO' PASSING XMLTYPE('<?xml version="1.0" encoding="gb2312" ?>&xml') AS B COL

Oracle解析 xml 记录一下(未完待续)

Oracle解析 xml 记录一下. SQL> desc xmlparser; PROCEDURE FREEPARSER Argument Name                  Type                    In/Out Default? ------------------------------ ----------------------- ------ -------- P                              RECORD          

ORACLE 解析xml字符串-转载的

1.xml字符串 /* <orderlist>        <order>        <orderid>1</orderid>        <ordernumber>857544544</ordernumber>        <orderprice>54</orderprice>        </order>                <order>        <

Java解析XML简单版

JAVA 文件 import java.io.File; import javax.xml.parsers.*; import org.w3c.dom.*; public class XmlReaderTest { public static void main(String[] args) throws Exception { DocumentBuilder db = DocumentBuilderFactory.newInstance() .newDocumentBuilder(); Doc

Oracle解析XML 节点信息并转换String 类型

select   xmltype(dataxml).extract('/data/sqr_mc/text()').getstringval()  as sqrmc from t_ins_formdata where bsnum='170215085821005401' 原文地址:https://www.cnblogs.com/auldlangsynezh/p/8178196.html

【java项目实战】dom4j解析xml文件,连接Oracle数据库

简介 dom4j是由dom4j.org出品的一个开源XML解析包.这句话太官方,我们还是看一下官方给出的解释.如下图: dom4j是一个易于使用的.开源的,用于解析XML,XPath和XSLT等语言的库.它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP等编程标准. 特点 dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用的特点,同时它也是一个开放源代码的软件.如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,例

HL7 2.6解析转XML(C#版)

项目中需要解析HL7,所以在网上找到解析代码,但错误很多,所以我修改了一下,测试好用. using System; using System.Collections.Generic; using System.Text; using System.Xml; using System.Text.RegularExpressions; namespace PT.Common { /// <summary> /// HL7解析器 /// </summary> public static

SQLServer解析xml到Oracle

写了一个程序:根据状态位读取SQLserver 中的一张表,下载其中一个字段的值,这个值是XML类型的,然后把这个XML文件的内容插入到另一Oracle数据库,并更新SQLServer表的标志位,表示这条记录已经更新过. 我的思路是用java写个webservice,然后再用C#写个windows 服务每过30分钟运行一次.用java写业务是因为我觉得java操作oracle相对方便一点.用C#写windows服务是是因为我只知道能用C#写windows service,后台静默运行挺好. 看似

基于oracle SQL Developer Data Modeler建模工具,解析xml,生成etljet代码

今天准备在 @zhangkai05 写的小工具model_sql基础上,进一步完善功能,使其更加自动化.方便建模人员开发etl任务. 源代码更改后 ,会发布到 git(url地址)上,逐步完善. 描述现状及问题 团队 数据仓库建模在2013年下开始使用 oracle sql developser datamodeler建模工具,之前一直用 powerdesigner,但由于后者是商业收费软件,公司又不打算购买.故经过调研,转向oracle建模工具.虽然其 易用性与 power designer