oracle 查询xmltype,在Oracle的XMLType里查询数据

5268f80b9b1e01f982625ef6fac83ca1.png

在Oracle的XMLtype的查询操作: 查询对象样例:表名:etab,第一列为varchar2() 名称为id,第二列为xmltype 列名为xmlcol,其中一行

在Oracle的XMLtype的查询操作:

查询对象样例:表名:etab,第一列为varchar2() 名称为id,第二列为xmltype 列名为xmlcol,

其中一行为,id字段的值为:aa

xmlcol字段的值为:

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的格式): BRA

还可以在之后加上/text()获取其内部文字(结果还是为clob的格式)

例如:

select t.id,t.xmlcol.extract('//ProductMetaData/SensorID/text()') from etab t

提取出的内容为(仍为CLOB的格式):BRA

或在之后加上/@att获取节点的属性值

例如:

select t.id,t.xmlcol.extract('//ProductMetaData/SesorID/@aa') 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

logo.gif

1428d0e076c3959ab11d28a39bc84fab.png

5268f80b9b1e01f982625ef6fac83ca1.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值