其实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

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>

xml version="1.0" 指定xml的版本

encoding="gb2312" 指定xml字符串的字符编码 

以上 < >中的内容可以省略

示例二(单行正常显示)

SELECT * FROM XMLTABLE('$B/ROW' PASSING

XMLTYPE('<?xml version="1.0" encoding="gb2312" ?>&xml') AS B

COLUMNS

TP_ID   NUMBER              PATH        '/ROW/TP_ID',

TP_NAME VARCHAR2(50)        PATH        '/ROW/TP_NAME',

TP_PARENTID NUMBER          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/ROW' PASSING

XMLTYPE('<?xml version="1.0" encoding="gb2312" ?>&xml') AS B

COLUMNS

TP_ID   NUMBER              PATH        '/ROW/TP_ID',

TP_NAME VARCHAR2(50)        PATH        '/ROW/TP_NAME',

TP_PARENTID NUMBER          PATH        '/ROW/TP_PARENTID',

TP_SNAME VARCHAR2(50)       PATH        '/ROW/TP_SNAME');

<ROW>

<TP_ID>112</TP_ID>

<TP_NAME>计算机网络技术</TP_NAME>

<TP_PARENTID>0</TP_PARENTID>

<TP_SNAME>R</TP_SNAME>

</ROW>

--反写语句如下:

insert into XMLTABLE (TP_ID, TP_NAME, TP_PARENTID, TP_SNAME) values (112, '计算机网络技术', 0, 'R');

示例四 (xml文件中字符不能添加单引号  ’ 和 双引号 ")-

SELECT * FROM XMLTABLE('$B/DEAL_BASIC/USER_DEAL_INFO' PASSING

XMLTYPE(' &XML') AS B

COLUMNS USER_DEAL_ID NUMBER         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>

--反写语句如下:  insert into XMLTABLE (USER_DEAL_ID, DEAL_INURE_TIME, DEAL_EXPIRE_TIME)  values ('1000100001', '"ORACLE"', '30000101');

示例四(多行正常显示)

SELECT * FROM XMLTABLE('$B/ORDERLIST/ORDER' PASSING

XMLTYPE(' &XML') AS B

COLUMNS ORDERID    NUMBER     PATH    '/ORDER/ORDERID',

ORDERNUMBER        NUMBER     PATH    '/ORDER/ORDERNUMBER',

ORDERPRICEE        NUMBER     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>

oracle解析xml完成版第二次修改的更多相关文章

  1. oracle解析xml完成版

    SELECT * FROM XMLTABLE('$B/DEAL_BASIC/USER_DEAL_INFO' PASSING XMLTYPE('<?xml version="1.0&qu ...

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

    Oracle解析 xml 记录一下. SQL> desc xmlparser; PROCEDURE FREEPARSER Argument Name                  Type  ...

  3. ORACLE 解析xml字符串-转载的

    --------------------------方法一------------------------------------- 1.xml字符串 /* <orderlist>     ...

  4. oracle解析xml(增加对9i版本的支持)

    --方法1  SELECT * FROM  XMLTABLE('$B/DEAL_BASIC/USER_DEAL_INFO' PASSING     XMLTYPE('<?xml version= ...

  5. 解析XML文件时做得修改

    在.h文件中找到需要在Build Settings中设置的东西,查找Header Search Paths,然后添加/usr/include/libxml2

  6. python 解析XML python模块xml.dom解析xml实例代码

    分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...

  7. HL7 2.6解析转XML(C#版)

    HL7 2.6解析转XML(C#版) 项目中需要解析HL7,所以在网上找到解析代码,但错误很多,所以我修改了一下,测试好用. using System; using System.Collection ...

  8. SQLServer解析xml到Oracle

    写了一个程序:根据状态位读取SQLserver 中的一张表,下载其中一个字段的值,这个值是XML类型的,然后把这个XML文件的内容插入到另一Oracle数据库,并更新SQLServer表的标志位,表示 ...

  9. 使用DOM解析XML文件,、读取xml文件、保存xml、增加节点、修改节点属性、删除节点

    使用的xml文件 <?xml version="1.0" encoding="GB2312" ?> <PhoneInfo> <Br ...

随机推荐

  1. ExtJS简单的动画效果(ext js淡入淡出特效)

    1.html页面:Application HTML file - index.html <html> <head> <title>ExtJs fadeIn() an ...

  2. UIPickerView 地区解析 -- 全国省、市、区 plist 解析 -- 读取UIPickerView 当前显示内容

    一个简单的plist 解析过程,借助UIPickerView 实现了手选全国的 省市区 方法, 源码中有详细注释:长句自己可以拆开看,最好的方法是,拆开,并打印,查看每一步打印的结果,结合Plist文 ...

  3. Qt Creator Valgrind内存分析前端(分析Nginx内存)

    Linux上使用Qt Creator进行C/C++开发http://my.oschina.net/eechen/blog/166969Qt Creator GDB调试前端(调试Nginx):http: ...

  4. C# DataGridView 导出 Excel(根据Excel版本显示选择不同后缀格式xls或xlsx)

    /// <summary> /// DataGridView导出至Excel,解决问题:打开Excel文件格式与扩展名指定格式不一致 /// </summary> /// &l ...

  5. 图论(网络流):[HNOI 2013]切糕

    [HNOI 2013]切糕 第三题:切糕(程序文件名:cake.exe)100 分,运行时限:5s 经过千辛万苦小A 得到了一块切糕,切糕的形状是长方体,小A 打算拦腰将切糕切成两半分给小B.出于美观 ...

  6. WPF之插件开发

    一:解决方案管理器截图 效果图: 二:简单功能说明 IMsg定义了一个接口,MYPlugin1实现接口功能,”插件式开发“实现程序运行时再调用非本身引用的dll文件,调用该dll的方法实现功能 三:I ...

  7. Failed to execute goal org.apache.maven.plugins:maven-clean-plugin:2.5:clean (default-clean) on project taotao-manager-web: Failed to clean project: Failed to delete \target\tomcat\logs\access_log.201

    点击console右上角叉号然后再点击红色小方形terminate

  8. mysql数据类型介绍

    一.int.bigint.smallint 和 tinyint的区别详细介绍 bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854 ...

  9. 自动开机和自动关机设定方法(包括linux和windows)

    (一) linux 机器 1.关机 : 编辑 /etc/crontab添加一条并且保证crontab服务的运行即可 f1 f2 f3 f4 f5 root sudo shutdown –h now 假 ...

  10. Linux命令 - 删除文件(夹)

    1.删除文件夹 rm –rf /var/test 将会删除/var/test目录以及其下的所有文件.文件夹 2.删除文件 rm -f /var/test/test.txt 将会强制删除/var/tes ...