mysql 多个值连成串_SQL语句中把多条记录同一字段的值连接成一个字符串显示结果集(sql stuff) | 学步园...

SELECT STUFF('abcdef', 2, 3, 'ijklmn');

结果:aijklmndf。

1.

if object_id('[tb]') is not null drop table [tb]

go

create table [tb]([Inv] int,[order] varchar(4))

insert [tb]

select 10001,'P111' union all

select 10001,'P112' union all

select 10001,'P113' union all

select 10002,'P114' union all

select 10002,'P115'

--------------开始查询--------------------------

select inv, [order]=stuff((select ','+[order] from tb t where Inv=tb.Inv for xml path('')), 1, 1, '')

from tb

group by Inv

select id1, [id3]=stuff((select ','+id3 from id_t t where id1=id_t.id1 for xml path('')), 1, 1, '')

from id_t GROUP BY id1

2.

001

00101

20

001

00101

80

001

00101

75

002

00101

20

002

00101

10

003

00101

70

004

00101

70

004

00101

70

004

00101

70

id1

id2

id3

if object_id('f_str') is not null drop function f_str

go

CREATE FUNCTION dbo.f_str(@id int)

RETURNS varchar(8000)

AS

BEGIN

DECLARE @r varchar(8000)

SET @r = ''

SELECT @r = @r + ';' + id3

FROM id_t

WHERE id1=@id

RETURN STUFF(@r, 1, 1, '')

END

GO

-- 调用函数

SELECt id1, [order]=dbo.f_str(id1)

FROM id_t

GROUP BY id1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值