<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
根據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;
結果:
它將由指定的分隔符分隔將字序列連線成一個字串。 它不會在結果字串的末尾新增分隔符。
SELECT name, string_agg(code,';') files FROM @table1 GROUP BY name;
將如下從Excel複製的一欄資料,插入到表中行進顯示(同時去掉回車換行符,空白和Tab符號):
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;
結果:
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;
結果:
有如下資料表
需求就是將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, 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;
函數功能:切分字串, 返回一個列名為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 TABLE AS RETURN ( SELECT B.id FROM ( ( --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 b where b.id !=''
專門用來拆分字串。
SELECT t.id, t.name, t.description, v.value FROM test t CROSS APPLY STRING_SPLIT(t.description, ',')v;
到此這篇關於SQL Server一個字串拆分多行顯示或者多行資料合併成一個字串的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45