Oracle迁移到MogDB之XMLPARSE

背景

迁移时,在两个客户的项目中都遇到过XMLPARSE,我们来看下如何迁移。

Oracle

源端代码模拟

with xml_data as
(
select '<bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book></bookstore>' as xml_content
from dual
)
SELECT XMLPARSE(DOCUMENT xml_content WELLFORMED).getClobVal() AS extracted_data
FROM xml_data;

该代码目的为解析xml,返回里面的内容,输出结果如下:

SELECT XMLPARSE(DOCUMENT xml_content WELLFORMED).getClobVal() AS extracted_data
  7  FROM xml_data;

EXTRACTED_DATA
--------------------------------------------------------------------------------
<bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book>

MogDB

直接在MogDB中运行该语句会报错

ERROR:  syntax error at or near "WELLFORMED"
LINE 6: SELECT XMLPARSE(DOCUMENT xml_content WELLFORMED).getClobVal(...
                                             ^
Time: 15.594 ms

对于这点不用担心,MogDB也支持XMLPARSE,只是语法部分地方不一样,我们稍做更改即可。
可以去掉 WELLFORMED 与 getClobVal

with xml_data as
(
select '<bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book></bookstore>' as xml_content
from dual
)
SELECT XMLPARSE(DOCUMENT xml_content /*WELLFORMED*/)/*.getClobVal()*/ AS extracted_data
FROM xml_data;

正确输出如下:

                                        extracted_data                                        
----------------------------------------------------------------------------------------------
 <bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book></bookstore>
(1 row)

Time: 1.204 ms
orcl=# select version();
                                                                       version                                                                        
------------------------------------------------------------------------------------------------------------------------------------------------------
 (MogDB 5.0.6 build 048d70b4) compiled at 2024-03-07 05:56:09 commit 0 last mr 1804  on x86_64-unknown-linux-gnu, compiled by g++ (GCC) 7.3.0, 64-bit
(1 row)

Time: 0.981 ms

如果要返回结果为文本格式,可以加 ::text

orcl=# with xml_data as
orcl-# (
orcl(# select '<bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book></bookstore>' as xml_content
orcl(# from dual
orcl(# )
orcl-# SELECT XMLPARSE(DOCUMENT xml_content /*WELLFORMED*/)::text/*.getClobVal()*/ AS extracted_data
orcl-# FROM xml_data;
                                        extracted_data                                        
----------------------------------------------------------------------------------------------
 <bookstore><book><title>Harry Potter</title><author>J.K. Rowling</author></book></bookstore>
(1 row)

Time: 2.024 ms

参考:
https://docs.mogdb.io/zh/mogdb/v5.0/xml-functions

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值