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

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

概述

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

一、多行數(shù)據(jù)合并成一個字符串

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

結(jié)果:

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

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

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

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

1、拆一列數(shù)據(jù):

將如下從Excel復(fù)制的一欄數(shù)據(jù),插入到表中行進顯示(同時去掉回車換行符,空白和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;

結(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 @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;

結(jié)果:

2、拆多列數(shù)據(jù):

有如下數(shù)據(jù)表

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

先將該字段值統(tǒng)一替換為逗號分割,再將逗號分割替換轉(zhuǎn)為XML數(shù)據(jù)類型,再利用xml轉(zhuǎn)為多個行

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、創(chuàng)建自定義拆分函數(shù)

函數(shù)功能:切分字符串, 返回一個列名為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 TABLEAS    RETURN     (SELECT B.idFROM   (   (  --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 bwhere b.id !=""

4、SQL Server 2016新增了string_split函數(shù)

專門用來拆分字符串。

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

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

標(biāo)簽: MsSQL
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩av一区二| 久久狠狠久久| 激情欧美日韩一区| 亚洲天堂免费| 日本一区福利在线| 亚洲国产不卡| 国产精品videossex久久发布 | 国产精品亚洲一区二区在线观看| 免费看久久久| 欧美黑人做爰爽爽爽| 国产主播一区| 中文字幕亚洲在线观看| 国产精品啊v在线| 欧洲激情综合| 国产精品白浆| 日韩专区在线视频| 精品久久电影| 欧美日韩99| 人人精品亚洲| 国产精品66| 美国三级日本三级久久99 | 麻豆国产精品视频| 久久中文视频| 精品一区二区三区中文字幕视频| 中文字幕高清在线播放| 国产视频一区三区| 99精品在线观看| 久久精品国产免费| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩精品第二页| 日韩av资源网| 麻豆精品国产91久久久久久| 鲁鲁在线中文| 国产精品手机在线播放| 欧美中文一区二区| 麻豆91在线播放| 99精品视频在线| 爽好久久久欧美精品| 香蕉国产精品| 最新国产精品久久久| 欧美激情在线精品一区二区三区| 久久精品电影| 国产毛片一区二区三区| 高清精品久久| 三级亚洲高清视频| 欧洲av不卡| 一区二区亚洲精品| 91麻豆精品| 国产视频亚洲| 97精品国产| 国产精品天堂蜜av在线播放| 伊人久久亚洲美女图片| 日韩国产欧美视频| 伊人成人在线视频| 日韩精品专区| 国产精选一区| 国产精品尤物| 成人午夜网址| 亚洲欧美日韩视频二区| 丝袜美腿成人在线| 午夜精品久久久久久久久久蜜桃| 国产精品久久| 三级精品视频| 亚洲激情不卡| 高清在线一区| 久久超级碰碰| 日韩一二三区在线观看| 欧美~级网站不卡| 精品深夜福利视频| 国产日韩欧美高清免费| 中文字幕免费一区二区| 日韩午夜视频在线| 视频一区二区中文字幕| 黑丝一区二区三区| 亚洲午夜黄色| 日韩中文在线电影| 国产成人精品三级高清久久91| 亚洲视频二区| 日韩av中文字幕一区| 日韩不卡在线观看日韩不卡视频 | 久久高清国产| 国产香蕉精品| 99久久亚洲精品| 久久国产精品美女| 欧美日韩国产精品一区二区亚洲| 日韩av中文字幕一区二区三区| 色婷婷精品视频| 日韩在线网址| 丝袜美腿一区| 国产成人免费| 91久久久精品国产| 欧美国产精品| 亚洲免费精品| 日本不卡在线视频| 97在线精品| 久久精品国产99国产| 久久av资源| a国产在线视频| 欧美在线网站| 亚洲午夜免费| 国产精品.xx视频.xxtv| 日韩精品影视| 蜜臀久久99精品久久久久宅男 | 欧美日韩国产一区二区在线观看| 日韩高清一级| 999久久久精品国产| 伊人国产精品| 韩日一区二区三区| 亚洲免费专区| 精品欧美久久| 久久久久久夜| 日本午夜精品一区二区三区电影 | 国产精品一区二区三区四区在线观看| 色婷婷色综合| 亚洲精品四区| 国产二区精品| 国产精区一区二区| 国产视频网站一区二区三区| 久久精品国产成人一区二区三区| 日韩一区三区| 久久久久久久久成人| 欧美日韩国产在线一区| 免费黄网站欧美| 日韩欧美在线中字| 亚洲青青久久| 在线综合亚洲| а√天堂中文在线资源8| 成人福利视频| 黄色日韩在线| 国产精品欧美三级在线观看| 999国产精品视频| 伊伊综合在线| 欧美a级一区二区| 久久成人高清| 久久午夜影院| 国产精品探花在线观看| 国产麻豆一区| 国产情侣一区在线| 国产精品一在线观看| 国产欧美啪啪| 美女视频黄免费的久久| 亚洲精品无吗| 香蕉久久夜色精品国产| 色老板在线视频一区二区| 国产一区国产二区国产三区| 国产一区二区三区黄网站| 美女国产一区二区三区| 国产一区二区三区四区大秀| 欧美激情 亚洲a∨综合| 国产一区二区三区天码| 国内自拍视频一区二区三区| 亚洲最新无码中文字幕久久 | 日本精品不卡| 久久av影视| 久久久久久久欧美精品| 999精品在线| 国产剧情在线观看一区| 日韩一区二区三区免费视频| 狠狠色狠狠色综合日日tαg| 亚州av乱码久久精品蜜桃| 欧美日韩精品一本二本三本 | 久久免费精品| 精品国产精品国产偷麻豆| 亚洲精品国产嫩草在线观看| 国产视频一区三区| 亚洲免费一区三区| av高清不卡| 成人av三级| 蜜臀久久99精品久久久久久9 | 亚洲欧美高清| 日本午夜精品| 一区二区三区国产在线| 国产精品一区三区在线观看| 国产精品网在线观看| 麻豆理论在线观看| 亚洲天堂成人| 午夜国产一区二区| 日韩激情精品| 国产欧美一区二区三区国产幕精品 | 日韩大片在线观看| 在线国产精品一区| 黄色亚洲精品| 最近国产精品视频| av资源亚洲| 日韩精品一区二区三区免费观影| 99久久激情| 久久最新视频| 国产精品99久久久久久董美香| 日韩在线观看中文字幕| 91嫩草精品| 久久久久久自在自线| 久久久久国产精品一区三寸 | 欧美日韩精品免费观看视频完整 | 欧美一级久久| 国产乱码精品一区二区亚洲| 红杏一区二区三区| 日韩一区二区三区精品| 日韩毛片视频| 亚洲精品麻豆| 欧洲av一区二区|