有一表数据为数量 托号
18 1#
18 2#
18 3#
18 4#
19 5#改为 18 1#,2#,3#,4#
19 5#
请问有可行的sql语句吗?
18 1#
18 2#
18 3#
18 4#
19 5#改为 18 1#,2#,3#,4#
19 5#
请问有可行的sql语句吗?
解决方案 »
- 如何认识更多的中小企业老板
- ADO连接paradox 的一个奇怪的问题
- txt(或Word)导入数据库的问题,求救于各位大侠!!!!!!!在线等,,,,
- 请问在TreeView控件范围内如何判断鼠标当前点击的位置不是节点位置,而是空白区域?
- 请教高手
- 不同的类之间要怎样才能访问呢?
- 串口问题?(在线等待.....)
- tcxtreelist 每个 node设置不同properties 有人解决吗?QQ281482913 在线等!
- 怎样取一个指针指向内容的大小
- 有谁知道DELPHI中所有函数,及所有的用处等,关于函数方面的知识,或者说有没有这方面的书!!??
- toolbar上的toolbutton按钮设置位置无效?
- dll编程Access violation at address的问题
--建函数
create function dbo.heng_str(@c int) returns varchar(100)
as
begin
declare @str varchar(1000)
set @str = ''
select @str = @str + ',' + cast(托号 as varchar) from 表1 where 数量 = @c
set @str = right(@str , len(@str) - 1)
return @str
end-- 调用
select 数量 , 托号 = dbo.heng_str(数量) from 表1 group by 数量
--------
貌似没有
--*******************************************************************************************
表结构,数据如下:
id value
----- ------
1 aa
1 bb
2 aaa
2 bbb
2 ccc 需要得到结果:
id values
------ -----------
1 aa,bb
2 aaa,bbb,ccc
即:group by id, 求 value 的和(字符串相加) 1. 旧的解决方法(在sql server 2000中只能用函数解决。)
--=============================================================================
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go
--1. 创建处理函数
CREATE FUNCTION dbo.f_strUnite(@id int)
RETURNS varchar(8000)
AS
BEGIN
DECLARE @str varchar(8000)
SET @str = ''
SELECT @str = @str + ',' + value FROM tb WHERE id=@id
RETURN STUFF(@str, 1, 1, '')
END
GO
-- 调用函数
SELECt id, value = dbo.f_strUnite(id) FROM tb GROUP BY id
drop table tb
drop function dbo.f_strUnite
go
/*
id value
----------- -----------
1 aa,bb
2 aaa,bbb,ccc
(所影响的行数为 2 行)
*/
--===================================================================================
2. 新的解决方法(在sql server 2005中用OUTER APPLY等解决。)
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go
-- 查询处理
SELECT * FROM(SELECT DISTINCT id FROM tb)A OUTER APPLY(
SELECT [values]= STUFF(REPLACE(REPLACE(
(
SELECT value FROM tb N
WHERE id = A.id
FOR XML AUTO
), ' ', ''), 1, 1, '')
)N
drop table tb /*
id values
----------- -----------
1 aa,bb
2 aaa,bbb,ccc (2 行受影响)
*/ --SQL2005中的方法2
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go select id, [values]=stuff((select ','+[value] from tb t where id=tb.id for xml path('')), 1, 1, '')
from tb
group by id /*
id values
----------- --------------------
1 aa,bb
2 aaa,bbb,ccc (2 row(s) affected) */ drop table tb 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/usher_gml/archive/2009/04/27/4128092.aspx
From (Select a.数量, a.托号, Row_Number() Over(Partition By a.数量 Order By a.托号) Rn From (select * from 表1 group by 数量,托号) a) T1
Start With T1.Rn = 1
Connect By T1.数量 = Prior T1.数量 And T1.Rn - 1 = Prior T1.Rn
Group By T1.数量;
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go
--1. 创建处理函数
CREATE FUNCTION dbo.f_strUnite(@id int)
RETURNS varchar(8000)
AS
BEGIN
DECLARE @str varchar(8000)
SET @str = ''
SELECT @str = @str + ',' + value FROM tb WHERE id=@id
RETURN STUFF(@str, 1, 1, '')
END
GO
-- 调用函数
SELECt id, value = dbo.f_strUnite(id) FROM tb GROUP BY id
drop table tb
drop function dbo.f_strUnite
go 能解释意思吗