设为首页 收藏本站
查看: 1121|回复: 0

[经验分享] Oracle中生成复杂结构的XML

[复制链接]

尚未签到

发表于 2018-9-22 09:52:18 | 显示全部楼层 |阅读模式
在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最外层的标签.
  总之,仁者见仁,智者见智吧 :)


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-599795-1-1.html 上篇帖子: RHEL5.2安装oracle10.2.0.1 下篇帖子: ORACLE TNSING报错(TNS-03505)的解决
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表