用于路径查询到T-SQL查询的XML

时间:2016-04-13 09:12:07

标签: sql sql-server xml tsql

我有一个非常复杂的查询,它使用' XML作为路径'返回XML。现在我需要将此查询作为常规T-SQL查询,但我很难转换它。我搜索了一个工具或其他主题,可以转换它或提供更多信息,如何轻松地将此查询转换为常规的t-sql查询。任何帮助将不胜感激!

SELECT 
    UPPER([dataareaid]) AS Company, 
    accountnum AS Code,
    name + ' [' +    
                    CASE ENTERPRISENUMBER
                        WHEN 'BTW BE 0000.000.097' 
                        THEN  TMMONATIONALREGISTRATIONNUMBER
                        ELSE 
                            CASE countryregionid 
                                WHEN 'BE' 
                                THEN ENTERPRISENUMBER
                                ELSE countryregionid + VATNUM
                            END
                    END + ']' AS Name, 
    'false'    AS PaymentDenied, 
    PAYMTERMID         AS PaymentTermCode,
    currency   AS Currency,
    AX_TMM.dbo.IS_ACCOUNT_ACTIVE(dataareaid,accountnum) AS Active,
    --recid AS Id, 
    'email' as OrderFormat,
    'efinance@test.be' as OrderEmail,
    'nl-NL' as [Language],
    CASE ENTERPRISENUMBER
        WHEN 'BTW BE 0000.000.097' 
        THEN  REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(TMMONATIONALREGISTRATIONNUMBER, '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
        ELSE 
            CASE countryregionid 
                WHEN 'BE' 
                THEN REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(ENTERPRISENUMBER, '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
                ELSE REPLACE(REPLACE(REPLACE(REPLACE(REPLACE((countryregionid + VATNUM), '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
            END
    END AS [SupplierIdentifiers/SupplierIdentifier/value],
    'PartyId' AS [SupplierIdentifiers/SupplierIdentifier/key],
    CASE ENTERPRISENUMBER
        WHEN 'BTW BE 0000.000.097' 
        THEN  REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(TMMONATIONALREGISTRATIONNUMBER, '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
        ELSE 
            CASE countryregionid 
                WHEN 'BE' 
                THEN REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(ENTERPRISENUMBER, '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
                ELSE REPLACE(REPLACE(REPLACE(REPLACE(REPLACE((countryregionid + VATNUM), '.', ''), ',', ''),'-',''),' ', ''),'BTW', '')
            END
    END AS [AdditionalDatas/AdditionalData/value],
    'PartyId' AS [AdditionalDatas/AdditionalData/name],
    (SELECT 
        accountnum AS [Bban], 
        ACCOUNTID AS [Name], 
        name AS [AdditionalData1], 
        ENTERPRISENUMBER AS [AdditionalData2], 
        bankiban AS [Iban], 
        swiftno AS [Swift], 
        AX_TMM.dbo.IS_BANKACCOUNT_DEFAULT(dataareaid,vendaccount,accountid) AS IsDefault
        --vendtable.recid AS Supplierid
    FROM 
        vendbankaccount
    WHERE 
        vendaccount = vendtable.accountnum 
        and DATAAREAID = vendtable.DATAAREAID
        and (expirydate = '1900-01-01 00:00:00.000' or expirydate > getdate())
    FOR xml path('SupplierBankAccount'), TYPE) AS [BankAccounts],     
    (SELECT (SELECT
                '' AS [ExternalCode],
                'PostalAddress' AS [Type], 
                'Maatschappelijke zetel ' + SMARTMDCMASTERACCOUNTTABLE.NAME AS [Name],
                'true' AS [IsDefault],
                maaccount + vendtable.DATAAREAID AS [ExternalIdentifier],



                (SELECT (SELECT 
                        'STREET_NAME' AS [AddressPartKey],
                        street AS [AddressPartText]
                        FROM 
                        SMARTMDCMASTERACCOUNTTABLE
                        LEFT OUTER JOIN ADDRESSCOUNTRYREGION
                        ON ADDRESSCOUNTRYREGION.ISOCODE = SMARTMDCMASTERACCOUNTTABLE.country
                        AND ADDRESSCOUNTRYREGION.DATAAREAID = SMARTMDCMASTERACCOUNTTABLE.DATAAREAID
                        WHERE 
                        maaccount = vendtable.accountnum 
                        FOR xml path('SupplierAddressPart'), TYPE),
                    (SELECT 
        'POSTAL_ZONE' AS [AddressPartKey],
        zipcode AS [AddressPartText]
        FROM 
        SMARTMDCMASTERACCOUNTTABLE
        WHERE 
        maaccount = vendtable.accountnum 

    FOR xml path('SupplierAddressPart'), TYPE
        ),
        (SELECT 
        'CITY_NAME' AS [AddressPartKey],
        city AS [AddressPartText]
        FROM 
        SMARTMDCMASTERACCOUNTTABLE
        WHERE 
        maaccount = vendtable.accountnum 

    FOR xml path('SupplierAddressPart'), TYPE
        ),
        (SELECT 
        'COUNTRY' AS [AddressPartKey],
        ADDRESSCOUNTRYREGION.NAME AS [AddressPartText]
        FROM 
        SMARTMDCMASTERACCOUNTTABLE
    LEFT OUTER JOIN ADDRESSCOUNTRYREGION
     ON ADDRESSCOUNTRYREGION.ISOCODE = SMARTMDCMASTERACCOUNTTABLE.country
        AND ADDRESSCOUNTRYREGION.DATAAREAID = SMARTMDCMASTERACCOUNTTABLE.DATAAREAID
    WHERE 
        maaccount = vendtable.accountnum 
    FOR xml path('SupplierAddressPart'), TYPE

        )
        FOR xml path('AddressParts'), TYPE)  
    FROM 
        SMARTMDCMASTERACCOUNTTABLE
    LEFT OUTER JOIN ADDRESSCOUNTRYREGION
     ON ADDRESSCOUNTRYREGION.ISOCODE = SMARTMDCMASTERACCOUNTTABLE.country
        AND ADDRESSCOUNTRYREGION.DATAAREAID = SMARTMDCMASTERACCOUNTTABLE.DATAAREAID
    WHERE 
        maaccount = vendtable.accountnum 
  FOR xml path('SupplierAddress'), TYPE) FOR xml path('SupplierAddresses'), TYPE) 
 FROM  vendtable
 WHERE DATAAREAID = 'TMM'
 FOR xml path('Supplier'), ROOT ('DocumentElement')

0 个答案:

没有答案