1

Excelスプレッドシートに変換できる形式でxmlを生成するSQLクエリを作成しようとしています。したがって、元のSQLテーブルには次のデータが含まれています

id  Run     Name    Outcome
1   Run1    Test1   1
2   Run2    Test2   2

これまでに作成できたSQLクエリは次のとおりです

select * from
(
    SELECT * from table1
  ) t
  for xml path('row'), root('sheetData')

これにより、次のxmlが生成されます

  <sheetData>
  <row r="1">
    <Run>Run1</Run>
    <Name>Test1</Name>
    <Outcome>1</Outcome>
  </row>
   <row r="2">
    <Run>Run2</Run>
    <Name>Test2</Name>
    <Outcome>2</Outcome>
  </row>
</sheetData>

だから私が取得する必要があるのは、次のxml形式です

  <?xml version="1.0" encoding="UTF-8"?>
<sheetData>
   <row r="1">
      <c r="A1" t="inlineStr">
         <is>
            <t>Run1</t>
         </is>
      </c>
      <c r="B1" t="inlineStr">
         <is>
            <t>Test1</t>
         </is>
      </c>
      <c r="C1" t="inlineStr">
         <is>
            <t>1</t>
         </is>
      </c>       
   </row>
   <row r="2">
      <c r="A2" t="inlineStr">
         <is>
            <t>Run2</t>
         </is>
      </c>
      <c r="B2" t="inlineStr">
         <is>
            <t>Test2</t>
         </is>
      </c>
      <c r="C2" t="inlineStr">
         <is>
            <t>2</t>
         </is>
      </c>       
   </row>
</sheetData>

今のところ、必要な出力を得るために最初の xml 形式の変換を行うことに頼っていますが、追加の変換を行わずにこれを直接生成するために使用できる SQL クエリを作成したいと考えていました。ご協力いただきありがとうございます。

4

1 に答える 1

1

以下はあなたが望むことをします。

DECLARE @Data TABLE (
    [id] INT,
    [Run] NVARCHAR(20),
    [Name] NVARCHAR(20),
    [Outcome] INT
)

INSERT INTO
    @Data ( [id], [Run], [Name], [Outcome] )
VALUES
    ( 1, 'Run1', 'Test1', 1 ),
    ( 2, 'Run2', 'Test2', 2 )

DECLARE @Xml XML = (
    SELECT
        [Id] AS [@r],
        (SELECT
            'A'+CONVERT(nvarchar(20), [Id]) AS [@r],
            'inlineStr' AS [@t],
            (SELECT
                [Run] AS [t]
            FOR XML PATH('is'), TYPE)
        FOR XML PATH('c'), TYPE),

        (SELECT
            'B'+CONVERT(nvarchar(20), [Id]) AS [@r],
            'inlineStr' AS [@t],
            (SELECT
                [Name] AS [t]
            FOR XML PATH('is'), TYPE)
        FOR XML PATH('c'), TYPE),

        (SELECT
            'C'+CONVERT(nvarchar(20), [Id]) AS [@r],
            'inlineStr' AS [@t],
            (SELECT
                [Outcome] AS [t]
            FOR XML PATH('is'), TYPE)
        FOR XML PATH('c'), TYPE)

    FROM
        @Data
    FOR XML PATH('row'), ROOT('sheetData'), TYPE
)
SELECT
    '<?xml version="1.0" encoding="UTF-8"?>'
    +CONVERT(NVARCHAR(MAX), @Xml)
于 2014-06-12T14:55:25.317 に答える