当前位置: 首页 > 面试题库 >

如何摆脱不需要的空XML标记?

江鹏飞
2023-03-14
问题内容

在下面的SQL XML中,recordingInfo如果所有这些字段都为空,我不想显示标签:

cc.source_album_title
cc.product_album_promo_title
cc.label
cc.catalogue_no
cc.isrc

这是我当前的查询:

 SELECT XMLAGG(XMLElement("Cue"  -- start level 5 tag for cue                                            
                             ,XMLFOREST( rownum as "cueId"    
                             ,cc.dn_ccst_status as "cueStatusType"                                        
                             ,decode(cc.dn_ccst_status,'5',cc.cup_code,NULL) as  "cueCupType" )                                                                                 
                                ,XMLElement("musicWork"  -- start level 6 tag for music title   
                                        ,XMLFOREST(cc.title as "musicTitle") 
                                        ,XMLElement("recordingInfo"  -- start level 7 tag for music title
                                                ,XMLFOREST( cc.source_album_title as "albumTitle"    
                                                            ,cc.product_album_promo_title as "promoTitle"                                        
                                                            ,cc.label as  "label"    
                                                            ,cc.catalogue_no as "catalogNumber"    
                                                            ,cc.isrc as "isrc")                                                                                   
                                                    )

                                          )  -- end level 6 tag for music title

                 )  -- end level 5 tag cue
              )
FROM creation_components cc
WHERE cc.prod_cre_surr_id = 22736214

recordingInfo如果上面列出的列都为空,这将生成带有两个空标记的XML :

<Cue>
   <cueId>1</cueId>
   <cueStatusType>5</cueStatusType>
   <cueCupType>W</cueCupType>
   <musicWork>
       <musicTitle>CLARE@RADIOWORKS.CO.UK</musicTitle>
       <recordingInfo></recordingInfo>
   </musicWork>
</Cue>

recordingInfo如果其中没有其他元素生成,如何停止包含空标记的它?


问题答案:

您可以使用嵌套XMLForest(.. as "recordingInfo")调用代替XMLElement("recordingInfo")

SELECT XMLAGG(XMLElement("Cue"  -- start level 5 tag for cue
  ,XMLFOREST( rownum as "cueId"
  ,cc.dn_ccst_status as "cueStatusType"
  ,decode(cc.dn_ccst_status,'5',cc.cup_code,NULL) as  "cueCupType" )
  ,XMLElement("musicWork"  -- start level 6 tag for music title
    ,XMLFOREST(cc.title as "musicTitle")
    ,XMLFOREST(
      XMLFOREST(cc.source_album_title as "albumTitle"
        ,cc.product_album_promo_title as "promoTitle"
        ,cc.label as  "label"
        ,cc.catalogue_no as "catalogNumber"
        ,cc.isrc as "isrc") as "recordingInfo"  -- start level 7 tag for music title
      )
    )  -- end level 6 tag for music title
  )  -- end level 5 tag cue
)
FROM creation_components cc
WHERE cc.prod_cre_surr_id = 22736214;

使用伪数据来匹配您的样本输出,并使用XMLSerialise包装器来美化输出:

WITH creation_components (prod_cre_surr_id, dn_ccst_status, cup_code, title,
  source_album_title, product_album_promo_title, label, catalogue_no, isrc) as
(
  SELECT 22736214, 5, 'W', 'CLARE@RADIOWORKS.CO.UK',
    null, null, null, null, null from dual
)
SELECT XMLSERIALIZE(Document
  XMLAGG(XMLElement("Cue"  -- start level 5 tag for cue
    ,XMLFOREST( rownum as "cueId"
    ,cc.dn_ccst_status as "cueStatusType"
    ,decode(cc.dn_ccst_status,'5',cc.cup_code,NULL) as  "cueCupType" )
    ,XMLElement("musicWork"  -- start level 6 tag for music title
      ,XMLFOREST(cc.title as "musicTitle")
      ,XMLFOREST(
        XMLFOREST(cc.source_album_title as "albumTitle"
          ,cc.product_album_promo_title as "promoTitle"
          ,cc.label as  "label"
          ,cc.catalogue_no as "catalogNumber"
          ,cc.isrc as "isrc") as "recordingInfo"  -- start level 7 tag for music title
        )
      )  -- end level 6 tag for music title 
    )  -- end level 5 tag cue
  )
  as CLOB INDENT SIZE = 2
)
FROM creation_components cc
WHERE cc.prod_cre_surr_id = 22736214;

得到

XMLSERIALIZE(DOCUMENTXMLAGG(XMLELEMENT("CUE"--STARTLEVEL5TAGFORCUE,XMLFOREST(ROW
--------------------------------------------------------------------------------
<Cue>
  <cueId>1</cueId>
  <cueStatusType>5</cueStatusType>
  <cueCupType>W</cueCupType>
  <musicWork>
    <musicTitle>CLARE@RADIOWORKS.CO.UK</musicTitle>
  </musicWork>
</Cue>

在后面的列中使用非空数据:

WITH creation_components (prod_cre_surr_id, dn_ccst_status, cup_code, title,
  source_album_title, product_album_promo_title, label, catalogue_no, isrc) as
(
  SELECT 22736214, 5, 'W', 'CLARE@RADIOWORKS.CO.UK',
    null, null, 'RadioWorks', null, null from dual
)
SELECT XMLSERIALIZE(Document
  XMLAGG(XMLElement("Cue"  -- start level 5 tag for cue
    ,XMLFOREST( rownum as "cueId"
    ,cc.dn_ccst_status as "cueStatusType"
    ,decode(cc.dn_ccst_status,'5',cc.cup_code,NULL) as  "cueCupType" )
    ,XMLElement("musicWork"  -- start level 6 tag for music title
      ,XMLFOREST(cc.title as "musicTitle")
      ,XMLFOREST(
        XMLFOREST(cc.source_album_title as "albumTitle"
          ,cc.product_album_promo_title as "promoTitle"
          ,cc.label as  "label"
          ,cc.catalogue_no as "catalogNumber"
          ,cc.isrc as "isrc") as "recordingInfo"  -- start level 7 tag for music title
        )
      )  -- end level 6 tag for music title
    )  -- end level 5 tag cue
  )
  as CLOB INDENT SIZE = 2
)
FROM creation_components cc
WHERE cc.prod_cre_surr_id = 22736214;

额外的标记仍会出现:

XMLSERIALIZE(DOCUMENTXMLAGG(XMLELEMENT("CUE"--STARTLEVEL5TAGFORCUE,XMLFOREST(ROW
--------------------------------------------------------------------------------
<Cue>
  <cueId>1</cueId>
  <cueStatusType>5</cueStatusType>
  <cueCupType>W</cueCupType>
  <musicWork>
    <musicTitle>CLARE@RADIOWORKS.CO.UK</musicTitle>
    <recordingInfo>
      <label>RadioWorks</label>
    </recordingInfo>
  </musicWork>
</Cue>


 类似资料:
  • 问题内容: 到目前为止,给我带来了很多麻烦,所以我想摆脱它。尽管spring框架文档清楚地说明了应该做的事情,但实际上 并没有摘要列表。 所以我一直坚持删除并得到错误 -在名称为的中找不到带有请求的映射 对于所有应该由控制器类解决的Url(在这种情况下:)。有什么建议可以让我了解更多信息吗?我非常想知道到底由代表什么标签。 问题答案: 你可以用来自定义定义的每个bean 。现在,javadocs详

  • 问题内容: 到现在为止,给我造成了很多麻烦,所以我想摆脱它。尽管spring框架文档清楚地说明了应该做的事情,但实际上 并没有摘要列表。 所以我坚持删除并现在得到错误 WARN osweb.servlet.PageNotFound-在DispatcherServlet中,名称为’workoutsensor’的URI [/ webapp / trainees]的HTTP请求未找到映射 对于所有应该由

  • 如上所述,我的XSL中只定义了一个命名空间,如下所示 xml: xsi="w3.org/2001/XMLSchema-instance" 但是,我的输出XML有2个命名空间,如下所示 xsi="w3.org/2001/XMLSchema-instance"xmlns: mea="ibm.com/maximo" 我可以摆脱xmlns: mea="ibm.com/maximo"

  • 我用全屏独占模式(FSEM)准备了一个程序。我将JFrame的装饰特性设置为“未装饰”,以去掉标题栏和所有的插图。 我的代码是: 然而,标题栏令人烦恼地留在那里。我如何摆脱它?我需要手动设置所有插页吗?

  • 问题内容: 我已经重写了我的网站php代码,并添加了MySQL存储过程。 在我的本地版本中,一切正常,但是在将网站上传到托管服务器后,我却收到致命错误“准备好的语句需要重新准备”。 有时页面加载,有时加载失败,我看到此错误。那是什么? 更新: 移到VPS服务器后问题不再存在。 感谢帮助。 问题答案: 这是可能的:MySQL错误#42041 他们建议提高的价值。 您可以在MySQL文档中阅读有关重新

  • 我有JavaWebService代码在我的eclipse。我使用了@WebService@Webmethod,@XmlElements,@XmlType,@XmlAccessorType 现在我正在使用cxf框架中的java2ws命令生成wsdl。这是命令 我的wsdl文件包含agr0作为我不想要的名称,因为当我将其导入SoapUI时。它正在字段周围添加标记。 下面是带有arg0的wsdl部分 下

  • 问题内容: 这两个功能都可以使用,但是我正在使用这是一个不好的做法,因为某些下拉列表和文本字段将比其他字段需要更长的时间来填充,因此我必须使用最长的睡眠值才能避免错误,如何解决这些问题2个功能使用等待。 问题答案: 当你正在调用的 WebElement 项目 ,理想情况下,你应该调用 WebDriverWait 与 EC 的,所以你必须: 更换: 与: 作为下拉需要更长的时间来填补,所以你应该调用

  • 问题内容: 我正在使用Apache Derby嵌入式数据库在Maven项目中进行单元测试。不幸的是,每当运行测试时,我最终都会在项目根目录中找到该文件。数据库本身是在目录()中创建的,因此这不是问题。在查阅参考指南之后, 我尝试在JDBC url()上设置参数,但这似乎是针对其他日志的,因此仍然会出现。 任何帮助深表感谢。 问题答案: 您可以通过创建以下类来摆脱文件 并设置JVM系统属性,例如,使