久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

在 SQL Server 中讀取 xml 文件

Read xml file in SQL Server(在 SQL Server 中讀取 xml 文件)
本文介紹了在 SQL Server 中讀取 xml 文件的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在嘗試從 XML 讀取數據并在 SQL Server 中以表格形式顯示結果.

I am trying to read data from XML and display the results in tabular for in SQL Server.

XML 數據:

<GradeSets>
    <GradeSet name="ALevel" descriptor="ALevelGrade" equivalence="1" allowedVariants="SplitGrades,FineGrades" va_multiplier="100">
        <Grade id="A*" points="140" success="true" />
        <Grade id="A" points="120" success="true" />
        <Grade id="B" points="100" success="true" />
        <Grade id="C" points="80" success="true" />
        <Grade id="D" points="60" success="true" />
        <Grade id="E" points="40" success="true" />
        <Grade id="U" points="0" success="false" />
        <Grade id="X" points="0" success="false" />
        <Grade id="Q" points="0" success="false">
            <Meta key="excludeStudent">true</Meta>
        </Grade>
        <GradeGroup id="A*>E">
            <Grade>A*</Grade>
            <Grade>A</Grade>
            <Grade>B</Grade>
            <Grade>C</Grade>
            <Grade>D</Grade>
            <Grade>E</Grade>
        </GradeGroup>
        <GradeGroup id="A*>C">
            <Grade>A*</Grade>
            <Grade>A</Grade>
            <Grade>B</Grade>
            <Grade>C</Grade>
        </GradeGroup>
        <GradeGroup id="A*>B">
            <Grade>A*</Grade>
            <Grade>A</Grade>
            <Grade>B</Grade>
        </GradeGroup>
    </GradeSet>
    <GradeSet name="ALevel-Double" descriptor="ALevelGrade" equivalence="2" va_multiplier="200">
        <Grade id="A*A*" points="280" success="true" />
        <Grade id="A*A" points="260" success="true" />
        <Grade id="AA" points="240" success="true" />
        <Grade id="AB" points="220" success="true" />
        <Grade id="BB" points="200" success="true" />
        <Grade id="BC" points="180" success="true" />
        <Grade id="CC" points="160" success="true" />
        <Grade id="CD" points="140" success="true" />
        <Grade id="DD" points="120" success="true" />
        <Grade id="DE" points="100" success="true" />
        <Grade id="EE" points="80" success="true" />
        <Grade id="U" points="0" success="false" />
        <Grade id="X" points="0" success="false" />
        <Grade id="Q" points="0" success="false">
            <Meta key="excludeStudent">true</Meta>
        </Grade>
        <GradeGroup id="A*A*>EE">
            <Grade>A*A*</Grade>
            <Grade>A*A</Grade>
            <Grade>AA</Grade>
            <Grade>AB</Grade>
            <Grade>BB</Grade>
            <Grade>BC</Grade>
            <Grade>CC</Grade>
            <Grade>CD</Grade>
            <Grade>DD</Grade>
            <Grade>DE</Grade>
            <Grade>EE</Grade>
        </GradeGroup>
        <GradeGroup id="A*A*>CC">
            <Grade>A*A*</Grade>
            <Grade>A*A</Grade>
            <Grade>AA</Grade>
            <Grade>AB</Grade>
            <Grade>BB</Grade>
            <Grade>BC</Grade>
            <Grade>CC</Grade>
        </GradeGroup>
        <GradeGroup id="A*A*>BB">
            <Grade>A*A*</Grade>
            <Grade>A*A</Grade>
            <Grade>AA</Grade>
            <Grade>AB</Grade>
            <Grade>BB</Grade>
        </GradeGroup>
    </GradeSet>
</GradeSets>

我寫了這個查詢,但我無法讓它工作:

I wrote this query, but I cannot get it to work:

SELECT
   MY_XML.GradeSet.query('GradeSet').value('.', 'VARCHAR(20)') ,
   MY_XML.GradeSet.query('GradeGroup').value('.', 'VARCHAR(20)')
   
FROM (SELECT CAST(MY_XML AS xml)
      FROM OPENROWSET(BULK 'C:\Users\johno\OneDrive\Desktop\MyData\MyDataImport.xml', SINGLE_BLOB) AS T(MY_XML)) AS T(MY_XML)
      CROSS APPLY MY_XML.nodes('GradeSets/GradeSet') AS MY_XML (GradeSet);

電流輸出

(No column name)    (No column name)
                     A*ABCDEA*ABCA*AB
                     A*A*A*AAAABBBBCCCCDD

預期輸出公會

推薦答案

請嘗試以下操作.如果它不是您所需要的,但它會給您一個良好的開端.

Please try the following. If it is not exactly what you need, but it will give you a good head start.

SQL

-- directly from the XML file as a virtual DB table on the file system
;WITH rs (xmldata) AS
(
   SELECT TRY_CAST(BulkColumn AS XML) AS BulkColumn 
   FROM OPENROWSET(BULK 'e:\Temp\JonWay.xml', SINGLE_BLOB) AS x
), cte AS
(
    SELECT a.value('@name', 'NVARCHAR(20)') AS [name]
       , a.value('@descriptor','NVARCHAR(50)') AS descriptor
       , a.value('@equivalence','INT') AS equivalence
       , a.value('@allowedVariants','NVARCHAR(100)') AS allowedVariants
       , a.value('@va_multiplier','INT') AS va_multiplier
       , b.value('@id','NVARCHAR(10)') AS id
       , b.value('@points','INT') AS points
       , b.value('@success','NVARCHAR(10)') AS success
       , c.value('(./text())[1]','NVARCHAR(10)') AS meta
       , c.value('@key','NVARCHAR(30)') AS [KEY]
       , d.value('@id','NVARCHAR(30)') AS id2
       , e.value('(./text())[1]','NVARCHAR(30)') AS Grade
    FROM rs AS tbl
       CROSS APPLY tbl.xmldata.nodes('/GradeSets/GradeSet[@name="ALevel"]') AS t1(a)
       OUTER APPLY t1.a.nodes('Grade') AS t2(b)
       OUTER APPLY t2.b.nodes('Meta') AS t3(c)
       OUTER APPLY t1.a.nodes('GradeGroup[@id="A*&gt;E"]') AS t4(d)
       OUTER APPLY t4.d.nodes('Grade') AS t5(e)
), cte2 AS
(
    SELECT *
        , ROW_NUMBER() OVER (PARTITION BY id ORDER BY id, points) AS seq
    FROM cte
)
SELECT * FROM cte2
WHERE seq = 1
ORDER BY points DESC;

輸出

+--------+-------------+-------------+------------------------+---------------+----+--------+---------+------+----------------+------+-------+-----+
|  name  | descriptor  | equivalence |    allowedVariants     | va_multiplier | id | points | success | meta |      KEY       | id2  | Grade | seq |
+--------+-------------+-------------+------------------------+---------------+----+--------+---------+------+----------------+------+-------+-----+
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | A* |    140 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | A  |    120 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | B  |    100 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | C  |     80 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | D  |     60 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | E  |     40 | true    | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | Q  |      0 | false   | true | excludeStudent | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | U  |      0 | false   | NULL | NULL           | A*>E | A*    |   1 |
| ALevel | ALevelGrade |           1 | SplitGrades,FineGrades |           100 | X  |      0 | false   | NULL | NULL           | A*>E | A*    |   1 |
+--------+-------------+-------------+------------------------+---------------+----+--------+---------+------+----------------+------+-------+-----+

這篇關于在 SQL Server 中讀取 xml 文件的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Modify Existing decimal places info(修改現有小數位信息)
The correlation name #39;CONVERT#39; is specified multiple times(多次指定相關名稱“CONVERT)
T-SQL left join not returning null columns(T-SQL 左連接不返回空列)
remove duplicates from comma or pipeline operator string(從逗號或管道運算符字符串中刪除重復項)
Change an iterative query to a relational set-based query(將迭代查詢更改為基于關系集的查詢)
concatenate a zero onto sql server select value shows 4 digits still and not 5(將零連接到 sql server 選擇值仍然顯示 4 位而不是 5)
主站蜘蛛池模板: 亚洲传媒在线 | 免费黄色a级毛片 | 久久久久久国产精品 | 狠狠操狠狠 | 一区二区三区在线电影 | 日韩一区二区三区在线观看 | 国产成人免费视频网站视频社区 | 一区二区三区免费观看 | a久久久久久 | 四虎影院欧美 | 国产一级一级国产 | 国产欧美日韩在线一区 | 精品一区二区三区入口 | 第一色在线 | a级片播放 | 国产自产21区 | 成人精品在线观看 | 国产乱人伦精品一区二区 | 天堂综合网久久 | 久久久久久av | xnxx 日本免费 | 黄片毛片| 黑人巨大精品欧美黑白配亚洲 | 国产综合在线视频 | 国产精品一区二区免费看 | 中文字幕在线免费观看 | 狠狠狠干 | 国内自拍偷拍 | 精品国产黄a∨片高清在线 www.一级片 国产欧美日韩综合精品一区二区 | 亚洲国产精品久久久久久 | 欧美午夜精品 | 欧美 日韩 国产 一区 | 天天爱av| 日韩在线看片 | 欧美性生活免费 | 手机av免费在线 | 日韩最新网址 | 日韩和的一区二在线 | 亚洲成人免费视频在线观看 | 成人在线不卡 | 黄色三级毛片 |