html5教程-在Oracle的XMLType里查询数据

发布时间:2018-12-18 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了html5教程-在Oracle的XMLType里查询数据脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

XMLtype的查询操作:
查询对象样例:表名:etab,第一列为varchar2() 名称为id,第二列为xmltype 列名为xmlcol,
其中一行为,id字段的值为:aa
xmlcol字段的值为:
[html]
<ProductMetaData> 
    <SatelliteID>02B</SatelliteID>     
    <ReceiveStationID>BRA</ReceiveStationID> 
    <SensorID aa='ExAttr'>CCD</SensorID> 
    <ReceiveTime>2003-06-30 22:12:24</ReceiveTime> 
    <OrbitID>448</OrbitID> 
</ProductMetaData> 


 
1:extract
作用:提取出XML串中指定节点的值(包含节点两端的标记),结果还是为clob的格式
可用column.extract('//xxx/xx'),或extract(column,'//xxx/xx')的语法
    例如: 
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID') from etab t
    select t.id,extract(t.xmlcol,'//ProductMetaData/SensorID') from etab t
    提取出的内容为(仍为CLOB的格式): <SensorID aa='ExAttr'>BRA</SensorID>
 
还可以在之后加上/text()获取其内部文字(结果还是为clob的格式)
    例如:
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID/text()') from etab t
    提取出的内容为(仍为CLOB的格式):BRA
 
或在之后加上/@att获取节点的属性值
    例如:
    select t.id,t.xmlcol.extract(www.2cto.com) from etab t
    提取出的内容为(仍为CLOB的格式):ExAttr
 
对于查找到的结果,可以使用getnumberval()或getstringval()函数将结果转化为需要的文字或数字
    例如:
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID/text()').getstringval() from etab t
    提取出的内容为(文本格式):BRA
 
    select t.id,t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() from etab t
    提取出的内容为(数字格式,可用于条件判断,例如大于小于):448
 
    提取内容作为条件判断:
    select t.id from etab t where t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() > 440
 
2.extactrvalue
作用:提取出XML串中指定节点的值(不包含节点两端的标记),结果为文本格式(如果值是数字的话,好像也可以认为是数字格式,也能用于查询里的条件判断)
只能使用extractvalue(column,'//xxx/xx')的格式
    例如:
    select t.id,extractvalue(t.xmlcol,'//ProductMetaData/SensorID') from etab t
    提取出的内容为文本格式的PMS
   
    select t.id from etab t where t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() > 2440
 

作者:rrrrssss00

XMLtype的查询操作:
查询对象样例:表名:etab,第一列为varchar2() 名称为id,第二列为xmltype 列名为xmlcol,
其中一行为,id字段的值为:aa
xmlcol字段的值为:
[html]
<ProductMetaData> 
    <SatelliteID>02B</SatelliteID>     
    <ReceiveStationID>BRA</ReceiveStationID> 
    <SensorID aa='ExAttr'>CCD</SensorID> 
    <ReceiveTime>2003-06-30 22:12:24</ReceiveTime> 
    <OrbitID>448</OrbitID> 
</ProductMetaData> 


 
1:extract
作用:提取出XML串中指定节点的值(包含节点两端的标记),结果还是为clob的格式
可用column.extract('//xxx/xx'),或extract(column,'//xxx/xx')的语法
    例如: 
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID') from etab t
    select t.id,extract(t.xmlcol,'//ProductMetaData/SensorID') from etab t
    提取出的内容为(仍为CLOB的格式): <SensorID aa='ExAttr'>BRA</SensorID>
 
还可以在之后加上/text()获取其内部文字(结果还是为clob的格式)
    例如:
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID/text()') from etab t
    提取出的内容为(仍为CLOB的格式):BRA
 
或在之后加上/@att获取节点的属性值
    例如:
    select t.id,t.xmlcol.extract(www.2cto.com) from etab t
    提取出的内容为(仍为CLOB的格式):ExAttr
 
对于查找到的结果,可以使用getnumberval()或getstringval()函数将结果转化为需要的文字或数字
    例如:
    select t.id,t.xmlcol.extract('//ProductMetaData/SensorID/text()').getstringval() from etab t
    提取出的内容为(文本格式):BRA
 
    select t.id,t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() from etab t
    提取出的内容为(数字格式,可用于条件判断,例如大于小于):448
 
    提取内容作为条件判断:
    select t.id from etab t where t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() > 440
 
2.extactrvalue
作用:提取出XML串中指定节点的值(不包含节点两端的标记),结果为文本格式(如果值是数字的话,好像也可以认为是数字格式,也能用于查询里的条件判断)
只能使用extractvalue(column,'//xxx/xx')的格式
    例如:
    select t.id,extractvalue(t.xmlcol,'//ProductMetaData/SensorID') from etab t
    提取出的内容为文本格式的PMS
   
    select t.id from etab t where t.xmlcol.extract('//ProductMetaData/OrbitID/text()').getnumberval() > 2440
 

作者:rrrrssss00

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! html5教程,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的html5教程-在Oracle的XMLType里查询数据全部内容,希望文章能够帮你解决html5教程-在Oracle的XMLType里查询数据所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:HTML