日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SQL Server一個字符串拆分多行顯示或者多行數據合并成一個字符串

瀏覽:56日期:2023-03-06 14:25:23

概述

  • STRING_AGG(合并):多行數據合并成一個字符串,以逗號隔開。
  • STRING_SPLIT(拆分):一個字符串,拆分成多行。

一、多行數據合并成一個字符串

1、通過 FOR xml path('') 合并字符串記錄

根據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 agroup by name;

結果:

2、MS SQL Server的2017新增了STRING_AGG()是一個聚合函數

它將由指定的分隔符分隔將字符串行連接成一個字符串。 它不會在結果字符串的末尾添加分隔符。

SELECT  name,   string_agg(code,";") files FROM @table1 GROUP BY name;

二、一個字符串拆分成多行

1、拆一列數據:

將如下從Excel復制的一欄數據,插入到表中行進顯示(同時去掉回車換行符,空白和Tab符號):

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 @table1insert into @table2  select   rtrim(ltrim(replace(bs.v1, char(9), "") )),a.xmlval1from (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) ) bswhere bs.v1 !="";select * from @table2;

結果:

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 @table2select rtrim(ltrim(replace(substring(A.col1, B.number, charindex(",", A.col1+",", B.number)-B.number) , char(9), "") )) as col2, B.numberfrom @table1 A     inner join master..spt_values B on charindex(",", ","+A.col1, B.number)=B.numberwhere B.type="P";select * from @table2;

結果:

2、拆多列數據:

有如下數據表

需求就是將Col1,Col2按照特定的字符串分割成多行

先將該字段值統一替換為逗號分割,再將逗號分割替換轉為XML數據類型,再利用xml轉為多個行

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, v2from   (   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, v2from   @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、創建自定義拆分函數

函數功能:切分字符串, 返回一個列名為id的表

--1. 創建fn_Split函數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 TABLEAS    RETURN     (SELECT B.idFROM   (   (  --A 的作用只是生成 "<v>a</v><v>b</v><v>d</v><v>c</v>" 的XML格式的數據, 提供數據源        SELECT [value] = CONVERT(XML, "<v>" + REPLACE(@str, @separator, "</v><v>") + "</v>")   ) A    OUTER APPLY   (  --B 的作用是將A中的 XML 數據的值枚舉出來轉換成行       SELECT id = N.v.value(".", "varchar(100)") FROM   A.[value].nodes("/v") N(v)   ) B       )    )GO

使用函數 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 bwhere b.id !=""

4、SQL Server 2016新增了string_split函數

專門用來拆分字符串。

SELECT t.id,       t.name,       t.description,       v.valueFROM test t    CROSS APPLY STRING_SPLIT(t.description, ",")v;

到此這篇關于SQL Server一個字符串拆分多行顯示或者多行數據合并成一個字符串的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持。

標簽: MsSQL
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品一区二区三区免费观影 | 激情欧美亚洲| 不卡av一区二区| 蜜臀久久99精品久久久画质超高清 | 国产精品一线| 鲁大师精品99久久久| 日韩欧美视频专区| 日韩一区二区久久| 日本三级亚洲精品| 国产成人精品福利| 亚洲综合欧美| 国产福利资源一区| 久久久蜜桃一区二区人| 久久午夜影视| 美女免费视频一区| 亚洲成av人片一区二区密柚| 中文在线日韩| 精品欠久久久中文字幕加勒比| 亚洲va在线| 婷婷亚洲精品| 国产成人免费视频网站视频社区| 午夜精品免费| 久久只有精品| 中文久久精品| 国产成人精选| 香蕉久久一区| 欧美一区二区三区激情视频 | 国产一区导航| 精品久久免费| 一区二区三区四区精品视频| 91视频一区| 亚洲人成亚洲精品| 卡一卡二国产精品| 日韩一级不卡| 高清一区二区三区av| 免费一区二区视频| 国产高清不卡| 日韩二区在线观看| 欧美福利专区| 精品免费在线| 蜜桃视频一区二区| av在线日韩| 国产美女视频一区二区| 久久午夜影视| 麻豆精品蜜桃| 精品国产不卡一区二区| 老司机精品视频网| 久久久精品午夜少妇| 视频在线观看国产精品| 国产乱论精品| 激情久久久久久久| 国产日韩视频在线| 久久久久网站| 91成人在线| 久久在线免费| 国产精品一区三区在线观看| 国产一区二区三区自拍| 国产精品亚洲人成在99www| 日韩高清中文字幕一区二区| 一区二区国产精品| 天堂а√在线最新版中文在线| 免费成人性网站| 国产一区二区三区成人欧美日韩在线观看| 久久久久久久久久久妇女| 欧美在线91| 亚洲二区视频| 狂野欧美性猛交xxxx| 丝袜诱惑制服诱惑色一区在线观看| 欧美极品中文字幕| 中文字幕日本一区| 在线 亚洲欧美在线综合一区| 国产福利片在线观看| 国产精品a级| 国产伦精品一区二区三区视频| 综合视频一区| 亚洲资源av| 国产精品婷婷| 伊人精品在线| 久久国产电影| 99视频精品全部免费在线视频| 中文在线资源| 伊人久久视频| 成人欧美一区二区三区的电影| 国产伊人久久| 高清久久精品| 国产一区二区精品久| 美女视频黄 久久| 欧美激情一区| 麻豆精品在线| 精品资源在线| 国内自拍视频一区二区三区| 美女视频网站久久| 麻豆国产91在线播放| 国产精品一区二区三区www| 日本aⅴ精品一区二区三区 | 美国三级日本三级久久99| 亚洲综合日韩| 免费人成精品欧美精品 | 一区免费在线| 99在线观看免费视频精品观看| 欧美午夜精彩| 亚洲激情黄色| 免费视频最近日韩| 亚洲精品黄色| 日韩一区二区三区高清在线观看| 日本在线成人| 国产欧美激情| 精品国产三区在线| 日韩专区精品| 欧美美女一区| 蜜桃视频免费观看一区| 日韩欧美久久| 国产精品亚洲一区二区在线观看 | 日本不卡一区二区三区| 欧美亚洲一级| 精品一区二区三区亚洲| 国产网站在线| 久久一区二区三区电影| 亚洲视频www| 日韩中文字幕1| 日韩三级一区| 欧美国产另类| 久久久久午夜电影| 丝袜诱惑制服诱惑色一区在线观看| 亚洲精品高潮| 精品一区二区三区免费看| 日韩一区三区| 亚洲在线网站| 国产麻豆精品久久| 伊人久久在线| 六月婷婷一区| 日本免费新一区视频| 美女久久99| 久久网站免费观看| 亚洲免费一区三区| 精品视频91| 91精品99| 精品日产乱码久久久久久仙踪林| 国产一级久久| 日本在线观看不卡视频| 国产欧美日韩一区二区三区四区| 麻豆一区二区在线| 午夜久久中文| 午夜国产精品视频免费体验区| 久久福利影视| 91成人福利| 美日韩一区二区三区| 福利视频一区| 女主播福利一区| 中文字幕av一区二区三区四区| 亚洲欧美网站在线观看| 欧美在线精品一区| 久久婷婷国产| 欧美日韩在线播放视频| 久久性天堂网| 国产精品一区二区精品视频观看| 精品亚洲二区| 欧美久久精品一级c片| 亚洲午夜免费| 国产黄色精品| 久久影院一区| 亚洲香蕉久久| 久久亚洲国产精品尤物| 国产99精品| 日本一区中文字幕| 九九99久久精品在免费线bt| 999视频精品| 天海翼亚洲一区二区三区| 免费一级欧美在线观看视频| 国产91精品对白在线播放| 日本不卡一区二区三区| 高清不卡亚洲| 综合激情五月婷婷| 成人精品久久| 蜜桃视频一区二区三区| 国产不卡精品| 99亚洲精品| 欧美成人aaa| 免费高潮视频95在线观看网站| 国产亚洲亚洲| 美女av一区| 亚洲一区日韩| 久久中文欧美| 老司机精品久久| 91日韩欧美| 日韩精彩视频在线观看| 欧洲亚洲一区二区三区| 日韩高清一级| 在线精品一区二区| 久久影院资源站| 影音先锋久久精品| 丝袜美腿一区二区三区| 神马久久午夜| 日韩免费小视频| 国产一区二区三区四区大秀| 日韩黄色av| 日本v片在线高清不卡在线观看| 国产亚洲一级| 日韩免费av| 国产v日韩v欧美v|