SQL查询合并字符串
来源:互联网 发布:国外718数据 编辑:程序博客网 时间:2024/05/18 02:05
a表
a列 b列
1 a
1 b
1 c
2 a
2 b
能否不用存储过程 直接sql 得到
1 a,b,c
2 a,b,c
这样的结果
可以的,用交叉方法
select a列,
max(case when b列='a' then 'a' else '' end) 列1,
max(case when b列='b' then 'b' else '' end) 列2,
max(case when b列='c' then 'c' else '' end) 列3
into temp_1219--插入临时表
from a表
group by a列
这个是静态的行列转换,
如果是动态的行列装换,也就是说你不知道表中a列的行数有很多,需要写过程对sql语句进行拼接
然后根据你的需要再对字段进行合并
select a列,列1+','+列2+','+列3 b列
into temp_1219_result--插入结果表
from temp_1219
/*--优化
update temp_1219
set 列2=','+列2
where len(列2)>0
update temp_1219
set 列3=','+列3
where len(列3)>0
select a列,列1+列2+列3 b列
into temp_1219_result2--插入结果表
from temp_1219
*/
案例2:
测试数据
编号 物料类别 产品编号
1 铅笔 0001
2 铅笔 0002
3 铅笔 0001
4 钢笔 0004
5 钢笔 0005
6 钢笔 0004
7 圆珠笔 0007
8 圆珠笔 0008
9 圆珠笔 0007
等等
要求实现以下效果:
编号 物料类别 产品编号
1 铅笔 0001,0002
2 钢笔 0004,0005
3 圆珠笔 0007,0008
**我的目的是如果不重复则合并产品编号,如果重复则舍弃**
create table T(编号 int, 物料类别 nvarchar(10), 产品编号 char(5))
insert T select 1, '铅笔', '0001'
union all select 2, '铅笔', '0002'
union all select 3, '铅笔', '0001'
union all select 4, '钢笔', '0004'
union all select 5, '钢笔', '0005'
union all select 6, '钢笔', '0004'
union all select 7, '圆珠笔', '0007'
union all select 8, '圆珠笔', '0008'
union all select 9, '圆珠笔', '0007'
create function fun(@物料类别 nvarchar(10))
returns nvarchar(200)
as
begin
declare @re nvarchar(200)
set @re=''
select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号
select @re=left(@re, len(@re)-1)
return @re
end
select distinct 物料类别, dbo.fun(物料类别) from T
--result
物料类别
---------- -------------------------------
钢笔 0004 ,0005
铅笔 0001 ,0002
圆珠笔 0007 ,0008
(3 row(s) affected)
后記:
核心語句中最后面的group by XXX 可舍棄重復。
select @re=@re+产品编号+',' from T where 物料类别=@物料类别 group by 产品编号
又一篇笔记,以备后用!!
需求:
有表tb,表有两个字段,分别为:id,value。
表中存有数据如下:id value
1 a
1 a1
1 a2
2 b
2 b1
3 c1
3 c2
需要通过查询实现:1 a,a1,a2
2 b,b1
3 c1,c2
实现方法:
1、sql2000 使用合并函数:
create function f_tb(@id int)
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str = ''
select @str = @str + ',' + cast(value as varchar) from tb where id = @id
set @str = right(@str , len(@str) - 1)
return(@str)
End
go
--调用自定义函数得到结果:
select distinct id ,dbo.f_tb(id) as value from t
2、sql2005 处理方式如下:
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
), '<N value="', ','), '"/>', ''), 1, 1, '')
)N
- SQL查询合并字符串
- SQL查询合并字符串
- sql把查询的多行记录合并成字符串
- sql查询将多个结果合并成一个字符串
- SQL查询语句 group by后, 字符串合并
- [sql server] 合并字符串
- [sql server] 合并字符串
- SQL合并字符串
- SQL如何合并查询结果
- SQL 字段charindex,stuff,ltrim, for xml path('') 操作字符串 合并查询结果项值
- SQL--字符串拆分,合并,替换
- SQL字符串模糊查询
- Master-Detail 查询 表体字符串合并
- SQL列合并的查询问题
- sql语句查询结果合并unionall用法
- 在Sql数据查询中,合并列
- 轻松掌握用SQL来合并查询
- Oracle之SQL基础--合并查询
- 从页面中下载数据到Txt文件中
- 常用js验证
- tomcat用户配置
- 周立功EASYARM2131搭建IAR环境
- SQL查询合并字符串
- SQL查询合并字符串
- activity中edittext如何在光标位置插入一个字符串
- 常用SQL语句
- xx
- Flex中利用URLLoader和URLVariables类导入文件的例子
- java集合类图
- Ubuntu-命令行启动屏幕保护
- 搜索引擎优化需要注意的地方
- 给RatingBar改图片