SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串
概述
- STRING_AGG(合并):多行數(shù)據(jù)合并成一個(gè)字符串,以逗號(hào)隔開。
- STRING_SPLIT(拆分):一個(gè)字符串,拆分成多行。
一、多行數(shù)據(jù)合并成一個(gè)字符串
1、通過 FOR xml path('') 合并字符串記錄
根據(jù)name字段,合并code
declare @table1 table ( id int ,code varchar(10) , name varchar(20) ); insert into @table1 ( id,code, name ) values ( 1, 'm1','a' ), ( 2, 'm2',null ), ( 3, 'm3', 'c' ), ( 4, 'm2','d' ), ( 5, 'm1','c' ); select * from @table1; select name, files=stuff((select ','+convert(varchar, code) from @table1 b where a.name=b.name for xml path('')), 1, 1, '') from @table1 a group by name;
結(jié)果:
2、MS SQL Server的2017新增了STRING_AGG()是一個(gè)聚合函數(shù)
它將由指定的分隔符分隔將字符串行連接成一個(gè)字符串。 它不會(huì)在結(jié)果字符串的末尾添加分隔符。
SELECT name, string_agg(code,';') files FROM @table1 GROUP BY name;
二、一個(gè)字符串拆分成多行
1、拆一列數(shù)據(jù):
將如下從Excel復(fù)制的一欄數(shù)據(jù),插入到表中行進(jìn)顯示(同時(shí)去掉回車換行符,空白和Tab符號(hào)):
1、利用XML解析方式(推薦)
declare @moulds varchar(4000); set @moulds='55-480730-03, 55-487780-01, , 55-487780-02 '; declare @table1 table(col1 nvarchar(4000)); declare @table2 table(col1 nvarchar(40),xmlval1 xml); insert into @table1 values(replace(@moulds, char(13)+char(10), '')); select * from @table1 insert into @table2 select rtrim(ltrim(replace(bs.v1, char(9), '') )),a.xmlval1 from (select convert(xml, '<n>'+replace(replace(col1, ',', ','), ',', '</n><n>')+'</n>') as xmlval1 from @table1) a cross apply(select k.n.value('.', 'nvarchar(80)') v1 from a.xmlval1.nodes('n') k(n) ) bs where bs.v1 !=''; select * from @table2;
結(jié)果:
2、利用字符串拆解
declare @moulds varchar(4000); set @moulds='55-480730-03, 55-487780-01, , 55-487780-02 '; declare @table1 table(col1 nvarchar(4000)); declare @table2 table(col1 nvarchar(40), pos int); insert into @table1 values(replace(@moulds, char(13)+char(10), '')); select * from @table1; insert into @table2 select rtrim(ltrim(replace(substring(A.col1, B.number, charindex(',', A.col1+',', B.number)-B.number) , char(9), '') )) as col2, B.number from @table1 A inner join master..spt_values B on charindex(',', ','+A.col1, B.number)=B.number where B.type='P'; select * from @table2;
結(jié)果:
2、拆多列數(shù)據(jù):
有如下數(shù)據(jù)表
需求就是將Col1,Col2按照特定的字符串分割成多行
先將該字段值統(tǒng)一替換為逗號(hào)分割,再將逗號(hào)分割替換轉(zhuǎn)為XML數(shù)據(jù)類型,再利用xml轉(zhuǎn)為多個(gè)行
declare @table1 table ( ID int , Col1 nvarchar(50) , Col2 nvarchar(50) ); insert into @table1 values ( 1, 'a,b,c', '誒,必,塞,地,伊' ); insert into @table1 values ( 2, 'w', N'三四,不知道咧' ); --方式一 select a.ID, a.Col1, a.Col2, v1, v2 from ( select ID, Col1, Col2, convert(xml, '<n>' + replace(replace(Col1, ',', ','), ',', '</n><n>') + '</n>') as xmlval1 , convert(xml, '<n>' + replace(replace(Col2, ',', ','), ',', '</n><n>') + '</n>') as xmlval2 from @table1 ) a cross apply ( select k.n.value('.', 'nvarchar(80)') v1 from a.xmlval1.nodes('n') k(n) ) bs cross apply ( select k.n.value('.', 'nvarchar(80)') v2 from a.xmlval2.nodes('n') k(n) ) ns; --方式二 select ID, t.Col1,t.Col2, v1, v2 from @table1 as t cross apply ( values (convert(xml, '<n>' + replace(replace(Col1, ',', ','), ',', '</n><n>')+ '</n>'), convert(xml, '<n>' + replace(replace(Col2, ',', ','), ',', '</n><n>')+ '</n>')) ) a (xmlval1 , xmlval2 ) cross apply ( select k.n.value('.', 'varchar(80)') as v1 from a.xmlval1.nodes('n') k(n)) bs cross apply ( select k.n.value('.', 'varchar(80)') as v2 from a.xmlval2.nodes('n') k(n) ) ns;
3、創(chuàng)建自定義拆分函數(shù)
函數(shù)功能:切分字符串, 返回一個(gè)列名為id的表
--1. 創(chuàng)建fn_Split函數(shù) IF EXISTS( SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID('fn_Split') AND (TYPE = 'FN' OR TYPE = 'TF' OR TYPE = 'IF') ) DROP FUNCTION fn_Split GO CREATE FUNCTION [dbo].[fn_Split] ( @str VARCHAR(MAX), @separator VARCHAR(10) ) RETURNS TABLE AS RETURN ( SELECT B.id FROM ( ( --A 的作用只是生成 '<v>a</v><v>b</v><v>d</v><v>c</v>' 的XML格式的數(shù)據(jù), 提供數(shù)據(jù)源 SELECT [value] = CONVERT(XML, '<v>' + REPLACE(@str, @separator, '</v><v>') + '</v>') ) A OUTER APPLY ( --B 的作用是將A中的 XML 數(shù)據(jù)的值枚舉出來轉(zhuǎn)換成行 SELECT id = N.v.value('.', 'varchar(100)') FROM A.[value].nodes('/v') N(v) ) B ) ) GO
使用函數(shù) SELECT id FROM fn_Split('a,b,d,c',',')
declare @moulds varchar(4000); set @moulds='55-480730-03, 55-487780-01, , 55-487780-02 '; declare @table1 table(id INT,col1 nvarchar(MAX)); INSERT INTO @table1 VALUES(1,replace(@moulds, char(13)+char(10), '')) INSERT INTO @table1 VALUES(2,replace(@moulds, char(13)+char(10), '')) select * from @table1; SELECT a.id,rtrim(ltrim(replace(b.id, char(10), '') )) AS item FROM @table1 a CROSS APPLY dbo.fn_Split(a.col1,',') AS b where b.id !=''
4、SQL Server 2016新增了string_split函數(shù)
專門用來拆分字符串。
SELECT t.id, t.name, t.description, v.value FROM test t CROSS APPLY STRING_SPLIT(t.description, ',')v;
到此這篇關(guān)于SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
有關(guān)數(shù)據(jù)庫SQL遞歸查詢?cè)诓煌瑪?shù)據(jù)庫中的實(shí)現(xiàn)方法
這篇文章主要介紹了有關(guān)數(shù)據(jù)庫SQL遞歸查詢?cè)诓煌瑪?shù)據(jù)庫中的實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2015-10-10SQLServer查詢某個(gè)時(shí)間段購(gòu)買過商品的所有用戶
這篇文章主要介紹了SQLServer查詢某個(gè)時(shí)間段購(gòu)買過商品的所有用戶,需要的朋友可以參考下2017-07-07SQL Server 高性能寫入的一些經(jīng)驗(yàn)總結(jié)
本篇博文將針對(duì)一些常用的數(shù)據(jù)庫性能調(diào)休方法進(jìn)行介紹,而且,為了編寫高效的SQL代碼,我們需要掌握一些基本代碼優(yōu)化的技巧,所以,我們將從一些基本優(yōu)化技巧進(jìn)行介紹2012-08-08SQL?Server數(shù)據(jù)庫備份和恢復(fù)數(shù)據(jù)庫的全過程
最近在功能調(diào)試前需要先將測(cè)試數(shù)據(jù)庫備份,然后功能調(diào)試之后再將測(cè)試數(shù)據(jù)庫還原,這樣就可以重復(fù)的進(jìn)行功能調(diào)試,這篇文章主要給大家介紹了關(guān)于SQL?Server數(shù)據(jù)庫備份和恢復(fù)數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下2022-06-06用SQL語句實(shí)現(xiàn)隨機(jī)查詢數(shù)據(jù)并不顯示錯(cuò)誤數(shù)據(jù)的方法
用SQL語句實(shí)現(xiàn)隨機(jī)查詢數(shù)據(jù)并不顯示錯(cuò)誤數(shù)據(jù)的方法...2007-11-11VS2022與SQL?server數(shù)據(jù)庫連接與訪問方法操作
在學(xué)習(xí)過程中我們常常需要連接數(shù)據(jù)庫對(duì)大量的數(shù)據(jù)進(jìn)行管理,下面這篇文章主要給大家介紹了關(guān)于VS2022與SQL?server數(shù)據(jù)庫連接與訪問的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01Sqlserver 高并發(fā)和大數(shù)據(jù)存儲(chǔ)方案
本文主要介紹了Sqlserver 高并發(fā)和大數(shù)據(jù)存儲(chǔ)方案。具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01SQL?Server解析/操作Json格式字段數(shù)據(jù)的方法實(shí)例
SQL SERVER沒有自帶的解析json函數(shù),需要自建一個(gè)函數(shù)(表值函數(shù)),下面這篇文章主要給大家介紹了關(guān)于SQL?Server解析/操作Json格式字段數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-08-08sqlserver 使用SSMS運(yùn)行sql腳本的六種方法
這篇文章主要介紹了sqlserver 使用SSMS運(yùn)行sql腳本的六種方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05