电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

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

概述

  • STRING_AGG(合并):多行數(shù)據(jù)合并成一個(gè)字符串,以逗號隔開。
  • 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 agroup by name;

結(jié)果:

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

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

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

二、一個(gè)字符串拆分成多行

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

將如下從Excel復(fù)制的一欄數(shù)據(jù),插入到表中行進(jìn)顯示(同時(shí)去掉回車換行符,空白和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)為多個(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, 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ù)功能:切分字符串, 返回一個(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 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一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持。

標(biāo)簽: MsSQL
相關(guān)文章:
主站蜘蛛池模板: 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 发光字|标识设计|标牌制作|精神堡垒 - 江苏苏通广告有限公司 | 扬州汇丰仪表有限公司 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 胶泥瓷砖胶,轻质粉刷石膏,嵌缝石膏厂家,腻子粉批发,永康家德兴,永康市家德兴建材厂 | 釜溪印象网络 - Powered by Discuz! | 箱式破碎机_移动方箱式破碎机/价格/厂家_【华盛铭重工】 | 采暖炉_取暖炉_生物质颗粒锅炉_颗粒壁炉_厂家加盟批发_烟台蓝澳采暖设备有限公司 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 【黄页88网】-B2B电子商务平台,b2b平台免费发布信息网 | 中药超微粉碎机(中药细胞级微粉碎)-百科 | 高清视频编码器,4K音视频编解码器,直播编码器,流媒体服务器,深圳海威视讯技术有限公司 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 点胶机_点胶阀_自动点胶机_智能点胶机_喷胶机_点胶机厂家【欧力克斯】 | 招商帮-一站式网络营销服务|搜索营销推广|信息流推广|短视视频营销推广|互联网整合营销|网络推广代运营|招商帮企业招商好帮手 | 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | 多功能三相相位伏安表-变压器短路阻抗测试仪-上海妙定电气 | 合肥活动房_安徽活动板房_集成打包箱房厂家-安徽玉强钢结构集成房屋有限公司 | 混合反应量热仪-高温高压量热仪-微机差热分析仪DTA|凯璞百科 | 荣事达手推洗地机_洗地机厂家_驾驶式扫地机_工业清洁设备 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 冷热冲击试验箱_温度冲击试验箱价格_冷热冲击箱排名_林频厂家 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 避光流动池-带盖荧光比色皿-生化流动比色皿-宜兴市晶科光学仪器 东莞爱加真空科技有限公司-进口真空镀膜机|真空镀膜设备|Polycold维修厂家 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 萃取箱-萃取槽-PVC萃取箱厂家-混合澄清槽- 杭州南方化工设备 | 茅茅虫AI论文写作助手-免费AIGC论文查重_写毕业论文降重 | Maneurop/美优乐压缩机,活塞压缩机,型号规格,技术参数,尺寸图片,价格经销商 | 压力控制器,差压控制器,温度控制器,防爆压力控制器,防爆温度控制器,防爆差压控制器-常州天利智能控制股份有限公司 | 模温机-油温机-电加热导热油炉-工业冷水机「欧诺智能」 | 水性漆|墙面漆|木器家具漆|水漆涂料_晨阳水漆官网 | 通用磨耗试验机-QUV耐候试验机|久宏实业百科| 贴片电容代理-三星电容-村田电容-风华电容-国巨电容-深圳市昂洋科技有限公司 | 泰来华顿液氮罐,美国MVE液氮罐,自增压液氮罐,定制液氮生物容器,进口杜瓦瓶-上海京灿精密机械有限公司 | 合景一建-无尘车间设计施工_食品医药洁净车间工程装修总承包公司 | 智能型高压核相仪-自动开口闪点测试仪-QJ41A电雷管测试仪|上海妙定 | 卧涛科技有限公司科技项目申报公司|高新技术企业申报|专利申请 | 讲师宝经纪-专业培训机构师资供应商_培训机构找讲师、培训师、讲师经纪就上讲师宝经纪 | 淬火设备-钎焊机-熔炼炉-中频炉-锻造炉-感应加热电源-退火机-热处理设备-优造节能 |