oracle 实现xml转换字段

SELECT 
    x.a,
    x.b,
    x.c,
    x.d,
    x.e,
    x.f,
    x.g
FROM 
    mytable d,
    XMLTABLE(
        '/root'
        PASSING XMLTYPE(d.content)
        COLUMNS
            a VARCHAR2(100) PATH 'a',
            b VARCHAR2(100) PATH 'b',
            c VARCHAR2(100) PATH 'c',
            d VARCHAR2(100) PATH 'd',
            e VARCHAR2(100) PATH 'e',
            f VARCHAR2(100) PATH 'f',
            g VARCHAR2(100) PATH 'g'
    ) x
    WHERE d.id = xxx

使用XMLTABLE函数需要的字段类型必须是XMLTYPE,我的content字段是使用的CLOB类型,所以我得转换为XMLTYPE类型。

  • XMLTABLE: 此函数将 XML 内容映射到一个关系表。可以指定要解析的 XML 路径和要返回的列。
  • PATH: 这里的路径指定了 XML 中的元素位置。每个列都对应 XML 中的一个字段。
  • VARCHAR2: 根据需要选择适当的大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值