jjzjj

sql-server - TSQL - FOR XML 添加数据到根节点

coder 2024-07-05 原文

我有一张 table :

CREATE TABLE [dbo].[xdOthPay]
(
    AccountNo char(10) NOT NULL,
    PaymentDoneOn datetime NULL,
    PaymentDoneBy char(30) NULL,
    InvoiceNumber char(10) NULL,
    AmountPaid decimal(12,3) NULL,
    Comments char(254) NULL,
    ClientID char(50) NULL,
    InstallID char(50) NULL,
    BatchID char(14) NOT NULL 
)

我需要通过 SSIS 和 SFTP 定期导出。

导出的接收方指定此格式:

<?xml version="1.0" encoding="utf-8"?>
<Payments ClientId="10865" xmlns="http://someUrl.com/core/xml/payment">
    <Payment>
        <AccountNo>VALUE</AccountNo>
        <PaymentDoneOn>VALUE</PaymentDoneOn>
        <PaymentDoneBy>VALUE</PaymentDoneBy>
        <InvoiceNumber>VALUE</InvoiceNumber>
        <AmountPaid>VALUE</AmountPaid>
        <Comments>VALUE</Comments>
    </Payment>
</Payments>

这是我的 T-SQL 语句:

SELECT 
    AccountNo,
    PaymentDoneOn,
    PaymentDoneBy,
    InvoiceNumber,
    AmountPaid,
    Comments
FROM 
    xdMOBOthPay
FOR XML PATH ('Payment'), ROOT ('Payments'), ELEMENTS

这导致:

<Payments>
    <Payment>
        <AccountNo> 972140</AccountNo>
        <PaymentDoneOn>2017-06-08T00:00:00</PaymentDoneOn>
        <PaymentDoneBy>R Entry BA13177 </PaymentDoneBy>
        <InvoiceNumber> 3804</InvoiceNumber>
        <AmountPaid>468.000</AmountPaid>
        <Comments>Non-Onl Payment </Comments>
    </Payment>
...

这非常接近,但我需要将数据放入根元素(付款)。表 ClientID 中的列需要作为 ClientID 属性包含在根元素中。 ClientID 将在表的所有行上保持一致。

我已经探索了几种方法,但我没有达到要求的格式。

谢谢 都灵

最佳答案

我建议您不要使用固定宽度的 char 列,而应使用 varchar 列。该示例添加了 namespace 并使 XML 略有不同,以根据需要获取所有内容。该示例针对一个特定的 ClientID 执行此操作,我想这就是您所需要的。

结果有一件不幸的事情,命名空间也应用于 Payment 元素。如果这 Not Acceptable ,则有一种变通方法,您可以在没有 XML 命名空间的情况下生成,并且可以应用字符串函数来插入命名空间属性。


CREATE TABLE #xdOthPay(
    AccountNo char(10) NOT NULL,
    PaymentDoneOn datetime NULL,
    PaymentDoneBy char(30) NULL,
    InvoiceNumber char(10) NULL,
    AmountPaid decimal(12,3) NULL,
    Comments char(254) NULL,
    ClientID char(50) NULL,
    InstallID char(50) NULL,
    BatchID char(14) NOT NULL );

INSERT INTO #xdOthPay(AccountNo,AmountPaid,BatchID,ClientID,Comments,InstallID,InvoiceNumber,PaymentDoneBy,PaymentDoneOn)
VALUES(972140,468,'bath-id',10865,'comments','install-id','invoicenr','paymentdoneby','20170101'),
      (972141,468,'bath-id',10865,'comments','install-id','invoicenr','paymentdoneby','20170101');

WITH XMLNAMESPACES(DEFAULT 'http://someUrl.com/core/xml/payment')
SELECT 
    10865 AS '@clientId',
    (
        SELECT 
            AccountNo,
            PaymentDoneOn,
            PaymentDoneBy,
            InvoiceNumber,
            AmountPaid,
            Comments
        FROM 
            #xdOthPay AS i
        WHERE
            i.ClientID=10865
        FOR 
            XML PATH ('Payment'), TYPE
    )
FOR 
    XML PATH ('Payments'), ELEMENTS;

DROP TABLE #xdOthPay;

结果:

<Payments xmlns="http://someUrl.com/core/xml/payment" clientId="10865">
  <Payment xmlns="http://someUrl.com/core/xml/payment">
    <AccountNo>972140    </AccountNo>
    <PaymentDoneOn>2017-01-01T00:00:00</PaymentDoneOn>
    <PaymentDoneBy>paymentdoneby                 </PaymentDoneBy>
    <InvoiceNumber>invoicenr </InvoiceNumber>
    <AmountPaid>468.000</AmountPaid>
    <Comments>comments                                                                                                                                                                                                                                                      </Comments>
  </Payment>
  <Payment xmlns="http://someUrl.com/core/xml/payment">
    <AccountNo>972141    </AccountNo>
    <PaymentDoneOn>2017-01-01T00:00:00</PaymentDoneOn>
    <PaymentDoneBy>paymentdoneby                 </PaymentDoneBy>
    <InvoiceNumber>invoicenr </InvoiceNumber>
    <AmountPaid>468.000</AmountPaid>
    <Comments>comments                                                                                                                                                                                                                                                      </Comments>
  </Payment>
</Payments>

关于sql-server - TSQL - FOR XML 添加数据到根节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45784641/

有关sql-server - TSQL - FOR XML 添加数据到根节点的更多相关文章

  1. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  2. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  3. ruby - 将 Bootstrap Less 添加到 Sinatra - 2

    我有一个ModularSinatra应用程序,我正在尝试将Bootstrap添加到应用程序中。get'/bootstrap/application.css'doless:"bootstrap/bootstrap"end我在views/bootstrap中有所有less文件,包括bootstrap.less。我收到这个错误:Less::ParseErrorat/bootstrap/application.css'reset.less'wasn'tfound.Bootstrap.less的第一行是://CSSReset@import"reset.less";我尝试了所有不同的路径格式,但它

  4. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  5. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  6. ruby - 可以通过多少种方法将方法添加到 ruby​​ 对象? - 2

    当谈到运行时自省(introspection)和动态代码生成时,我认为ruby​​没有任何竞争对手,可能除了一些lisp方言。前几天,我正在做一些代码练习来探索ruby​​的动态功能,我开始想知道如何向现有对象添加方法。以下是我能想到的3种方法:obj=Object.new#addamethoddirectlydefobj.new_method...end#addamethodindirectlywiththesingletonclassclass这只是冰山一角,因为我还没有探索instance_eval、module_eval和define_method的各种组合。是否有在线/离线资

  7. ruby - 如何在 Ruby 中向现有方法定义添加语句 - 2

    我注意到类定义,如果我打开classMyClass,并在不覆盖的情况下添加一些东西我仍然得到了之前定义的原始方法。添加的新语句扩充了现有语句。但是对于方法定义,我仍然想要与类定义相同的行为,但是当我打开defmy_method时似乎,def中的现有语句和end被覆盖了,我需要重写一遍。那么有什么方法可以使方法定义的行为与定义相同,类似于super,但不一定是子类? 最佳答案 我想您正在寻找alias_method:classAalias_method:old_func,:funcdeffuncold_func#similartoca

  8. ruby-on-rails - 添加回形针新样式不影响旧上传的图像 - 2

    我有带有Logo图像的公司模型has_attached_file:logo我用他们的Logo创建了许多公司。现在,我需要添加新样式has_attached_file:logo,:styles=>{:small=>"30x15>",:medium=>"155x85>"}我是否应该重新上传所有旧数据以重新生成新样式?我不这么认为……或者有什么rake任务可以重新生成样式吗? 最佳答案 参见Thumbnail-Generation.如果rake任务不适合你,你应该能够在控制台中使用一个片段来调用重新处理!关于相关公司

  9. ruby - 我如何添加二进制数据来遏制 POST - 2

    我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_

  10. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

随机推荐