如何查询 xmltype中的所有

 我来答
化清和
2016-12-21
知道答主
回答量:0
采纳率:0%
帮助的人:0
展开全部

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

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
?>

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式