当前位置: 首页 > news >正文

oracle中multiset()生成复杂结构的XML

oracle中multiset,Oracle中生成复杂结构的XML:

在Oracle中,我们可以通过DBMS_XML包来将SQL语句查出的数据转成XML文件.但有时候我们需要的是复杂的多层结构的XML.

比较以下两个结构

A --- a1 ---

A --- a1 ---

A --- a1 ---

B --- b1 ---

B --- b1 ---

C --- c1 ---

A ---

a1 ---

a2 ---

a3 ---

B ---

b1 ---

b2 ---

C ---

c1 ---

对于第一种结构的XML,我们只需要简单的将A和a关联查询并生成XML即可

这里我要说明的是如何生成第二种结构的XML

实例场景:

表XML_PRIMARY

表XML_SECONDARY

两个表有外键的关联,Primary是主表,Secondary是Primary的从表

create table XML_PRIMARY

(

P_ID NUMBER not null,

P_NAME VARCHAR2(20)

);

alter table XML_PRIMARY

add constraint PK_XML_PRIMARY primary key (P_ID)

using index;

create table XML_SECONDARY

(

S_ID NUMBER not null,

S_NAME VARCHAR2(10),

P_ID NUMBER

);

alter table XML_SECONDARY

add constraint PK_XML_SECONDARY primary key (S_ID)

using index;

alter table XML_SECONDARY

add constraint FK_XML_PRIM_SECO foreign key (P_ID)

references XML_PRIMARY (P_ID);

问题: 如何将从表的数据以独立的结构生成XML显示出来

解决办法: 将从表的数据以数据集合的形式查询出来

1. 建立与从表同构的对象类型

CREATE OR REPLACE TYPE Typ_o_Xml_Secondary AS OBJECT

(

s_Id NUMBER,

s_Name VARCHAR2(10),

p_Id NUMBER

)

2. 建立从表的表类型

CREATE OR REPLACE TYPE TYP_XML_SECONDARY AS TABLE OF TYP_O_XML_SECONDARY

3. 建立带从表数据集合的主表类型

CREATE OR REPLACE TYPE Typ_o_Xml_Primary AS OBJECT

(

p_Id NUMBER,

p_Name VARCHAR2(20),

s_Data Typ_Xml_Secondary

)

4. 利用Cast和Multiset将子查询转化为子结果集

SELECT Typ_o_Xml_Primary(p_Id,

p_Name,

CAST(MULTISET (SELECT s_Id, s_Name, p_Id

FROM Xml_Secondary

WHERE p_Id = Xml_Primary.p_Id) AS

Typ_Xml_Secondary)) AS Xml_Primary

FROM Xml_Primary

5. 将SQL转化为XML

CREATE OR REPLACE PROCEDURE Prc_Xml_Subxml AS

Qryctx Dbms_Xmlgen.Ctxhandle;

RESULT CLOB;

BEGIN

Qryctx := Dbms_Xmlgen.Newcontext('

SELECT Typ_o_Xml_Primary(p_Id,

p_Name,

CAST(MULTISET (SELECT s_Id, s_Name, p_Id

FROM Xml_Secondary

WHERE p_Id = Xml_Primary.p_Id) AS

Typ_Xml_Secondary)) AS Xml_Primary

FROM Xml_Primary

');

RESULT := Dbms_Xmlgen.Getxml(Qryctx);

Dbms_Output.Put_Line(RESULT);

END Prc_Xml_Subxml;

输出的结果实例:

1

Primary data 1

11

Sec 11

1

12

Sec 12

1

13

Sec 13

1

2

Primary data 2

21

Sec 21

2

22

Sec 22

2

3

Primary data 3

31

Sec 31

3

后续研究:

1. 其实,如果只是要数据的话,没有必要用Typ_o_Xml_Primary类型再做一次格式化,如下语句即可达到目的

SELECT p_Id,

p_Name,

CAST(MULTISET (SELECT s_Id, s_Name, p_Id

FROM Xml_Secondary

WHERE p_Id = Xml_Primary.p_Id) AS Typ_Xml_Secondary)

FROM Xml_Primary

但,结果会让XML中的标签变成,所以这里我用了一个结构来生成标签的名字.

或者

SELECT p_Id,

p_Name,

CAST(MULTISET (SELECT s_Id, s_Name, p_Id

FROM Xml_Secondary

WHERE p_Id = Xml_Primary.p_Id) AS Typ_Xml_Secondary) as XXX

FROM Xml_Primary

也可以去掉类似于的标签名,但就无法命名XML最外层的标签.

 

http://www.jsqmd.com/news/430509/

相关文章:

  • 2026年质量好的防爆压力表表壳/压力表表壳厂家热销推荐 - 品牌宣传支持者
  • 线条共生,身心同美|武汉瑜伽塑形课,禧悦带你解锁优雅体态 - 冠顶工业设备
  • 2026年口碑好的山东自卸式除铁器/永磁除铁器用户好评厂家推荐 - 品牌宣传支持者
  • Linux系统CH34x串口设备连接问题解决方案:从驱动安装到高级配置完全指南
  • 如何利用开源工具提升文档处理效率:EPubBuilder全功能解析
  • 基于单片机的智能衣柜控制系统设计(STM32)
  • 2026年知名的齿轮精密模具/冷热流道精密模具厂家热卖产品推荐(近期) - 品牌宣传支持者
  • 3步精通智能抢票工具:从配置到实战的效率提升指南
  • 突破分辨率枷锁:SRWE开源工具如何让窗口调整从技术难题变成创作自由(附隐藏商业价值)
  • Umi-CUT:智能图片批量处理工具的全方位应用指南
  • LiteLoaderQQNT-OneBotApi实战指南:从环境搭建到功能定制的6个核心步骤
  • 解放设计师:PhotoGIMP无缝过渡方案让专业图像编辑零成本革新
  • 2026年比较好的劳保工作服/宁波劳保工作服行业内口碑厂家推荐 - 品牌宣传支持者
  • 深入理解TCP四次挥手:状态转换全流程实战解析
  • TCP状态转换完全指南:从三次握手到四次挥手的深度解析
  • 静音不扰邻|静音家用健身器材哪个好?上海皓衍实测推荐,居家健身更安心 - 冠顶工业设备
  • XUnity.AutoTranslator:Unity翻译工具高效配置指南
  • 2026年知名的珠孔形尼龙扎带/自锁式尼龙扎带厂家采购参考指南 - 品牌宣传支持者
  • 如何突破单机游戏限制:Nucleus Co-Op实现本地多人分屏的创新方案
  • Umi-CUT:重新定义图片批量处理效率的智能解决方案
  • 惊爆!Anthropic怒斥中国AI“偷师”,1600万次对话背后的罗生门:到底谁在蒸馏谁?
  • m3u8-downloader颠覆式全攻略:跨平台M3U8视频高效下载解决方案
  • WeakReferenceMessenger
  • Ai2Psd矢量图层转换:破解设计协作流程断裂的自动化方案 | 提升跨软件协作效率300%
  • 如何通过DamaiHelper实现演唱会门票自动抢购?提升90%成功率的实用指南
  • 2026年口碑好的滚筒磁选机/湿式磁选机热门品牌厂家推荐 - 品牌宣传支持者
  • unrpa:RPA文件提取工具 游戏开发者与玩家的资源解包利器
  • AlistHelper:让Alist管理像使用手机App一样简单
  • 联想游戏本性能解锁工具:Lenovo Legion Toolkit全方位优化指南
  • 蓝牙基础(十一):蓝牙耳机音频编码、传输流程、声音延迟与失真