Sql Server 數據把列根據指定的內容拆分數據


今天由於工作需要,需要把數據把列根據指定的內容拆分數據

其中一條數據實例

 select id , XXXX FROM BIZ_PAPER where  id ='4af210ec675927fa016772bf7dd025b0'

 

 

 

拆分方法:

select t3.id ,t3.XXXX as XXXX from (
select A.id , B.XXXX  from (
SELECT id, XXXX = CONVERT(xml,'<root><v>' + REPLACE(XXXX , ',', '</v><v>') + '</v></root>') FROM BIZ_PAPER) A
outer apply(
SELECT XXXX = N.v.value('.', 'varchar(100)') FROM A.XXXX .nodes('/root/v') N(v)) B) t3 where t3.id ='4af210ec675927fa016772bf7dd025b0'

結果

 

 

 在自己研究這行代碼之后,做出如下講解,如果有錯誤的地方還請指教

SELECT id, XXXX = CONVERT(xml,'<root><v>' + REPLACE(XXXX , ',', '</v><v>') + '</v></root>') FROM BIZ_PAPER
這一行的重點在於CONVERT,XML是指類型,xml 數據類型實例拆分為關系數據,則 nodes() 方法非常有用,至於XML類型的數據,我后面進行補充

REPLACE 指按照 ' , ' 進行替換,並且按照指定的內容進行拼接

最后的結果為

 

outer apply

這個就是表的關聯,就像是left join ,但是沒有on 作為關聯條件,所以通過拆分之后多出來的數據就是通過這個進行關聯后產生的

 SELECT XXXX = N.v.value('.', 'varchar(100)') FROM A.XXXX .nodes('/root/v') N(v)

N.v.value('.','varchar(100)'),N是表,別名,v是列,value函數是讀取標簽之間的值,對於這個列子,讀取的為<v>和</v>中間的值;這個可以去了解 xml類型的常用的三個方法 :value()、nodes()、exist()

value的第一個參數是一個字符串文字,從 XML 實例內部檢索數據。 XQuery 必須最多返回一個值。 否則,將返回錯誤;

value的第二個參數是指將查詢結果轉化為何種類型的數據。

此處,'.'表示當前目錄,即<v>目錄,另外'..'表示上級目錄,'/'表示根目錄,這個跟Linux是一樣的

 

 

 總的來說,這個語句的重點在於xml類型的使用和outer apply的使用,其他的都很好理解。這個就是我自己理解后的講解,部分位置我自己也還沒有理解透


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM