这个问题有点复杂!!

loen113 2009-03-17 09:43:50
表a

货号 颜色 箱号 重量
001 红色 1 20
001 红色 2 40
001 红色 3 10
001 红色 4 23
001 红色 5 32
001 红色 6 45

001 黑色 4 23
001 黑色 5 32
001 白色 6 45
001 绿色 7 43
... ... .. ...

想得到以下
货号 颜色 箱号1 重量 箱号2 重量 箱号3 重量 箱号4 重量
001 红色 1 20 2 40 3 10 4 23
001 红色 5 32 6 45
001 黑色 4 23 5 32
001 白色 6 45
001 绿色 7 43

顺便问下,哪里有做DELPHI动态报表的例子,想学习下











...全文
68 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
Teng_s2000 2009-03-17
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 jinjazz 的回复:]
行列转换,搜索一大堆
[/Quote]

UP
百年树人 2009-03-17
  • 打赏
  • 举报
回复
---测试数据---
if object_id('[a]') is not null drop table [a]
go
create table [a]([货号] varchar(3),[颜色] varchar(4),[箱号] int,[重量] int)
insert [a]
select '001','红色',1,20 union all
select '001','红色',2,40 union all
select '001','红色',3,10 union all
select '001','红色',4,23 union all
select '001','红色',5,32 union all
select '001','红色',6,45 union all
select '001','黑色',4,23 union all
select '001','黑色',5,32 union all
select '001','白色',6,45 union all
select '001','绿色',7,43

---查询---
select a1.货号,a1.颜色,a1.箱号 as 箱号1,a1.重量,a2.箱号 as 箱号2,a2.重量,a3.箱号 as 箱号3,a3.重量,a4.箱号 as 箱号4,a4.重量
from
(select * from(select *,px=(select count(1)+1 from a where 颜色=ta.颜色 and 箱号<ta.箱号) from a ta) tb where px%4=1) a1
left join
(select * from(select *,px=(select count(1)+1 from a where 颜色=ta.颜色 and 箱号<ta.箱号) from a ta) tb where px%4=2) a2
on a1.货号=a2.货号 and a1.颜色=a2.颜色 and a2.px=a1.px+1
left join
(select * from(select *,px=(select count(1)+1 from a where 颜色=ta.颜色 and 箱号<ta.箱号) from a ta) tb where px%4=3) a3
on a1.货号=a3.货号 and a1.颜色=a3.颜色 and a3.px=a1.px+2
left join
(select * from(select *,px=(select count(1)+1 from a where 颜色=ta.颜色 and 箱号<ta.箱号) from a ta) tb where px%4=0) a4
on a1.货号=a4.货号 and a1.颜色=a4.颜色 and a4.px=a1.px+3

---结果---
货号 颜色 箱号1 重量 箱号2 重量 箱号3 重量 箱号4 重量
---- ---- ----------- ----------- ----------- ----------- ----------- ----------- ----------- -----------
001 红色 1 20 2 40 3 10 4 23
001 红色 5 32 6 45 NULL NULL NULL NULL
001 黑色 4 23 5 32 NULL NULL NULL NULL
001 白色 6 45 NULL NULL NULL NULL NULL NULL
001 绿色 7 43 NULL NULL NULL NULL NULL NULL

(所影响的行数为 5 行)
loen113 2009-03-17
  • 打赏
  • 举报
回复
货号 颜色 箱号1 重量 箱号2 重量 箱号3 重量 箱号4 重量
001 红色 1 20 2 40 3 10 4 23
001 红色 5 32 6 45
001 黑色 4 23 5 32
001 白色 6 45
001 绿色 7 43
箱号1至箱号4都是从表A的箱号获取的
dawugui 2009-03-17
  • 打赏
  • 举报
回复
create table tb(货号 varchar(10), 颜色 varchar(10), 箱号 int, 重量 int)
insert into tb values('001' , '红色' , 1 , 20 )
insert into tb values('001' , '红色' , 2 , 40 )
insert into tb values('001' , '红色' , 3 , 10 )
insert into tb values('001' , '红色' , 4 , 23 )
insert into tb values('001' , '红色' , 5 , 32 )
insert into tb values('001' , '红色' , 6 , 45 )
insert into tb values('001' , '黑色' , 4 , 23 )
insert into tb values('001' , '黑色' , 5 , 32 )
insert into tb values('001' , '白色' , 6 , 45 )
insert into tb values('001' , '绿色' , 7 , 43 )
go

select 货号 , 颜色,
max(case (px - 1)%4 when 0 then 箱号 end) 箱号1,
max(case (px - 1)%4 when 0 then 重量 end) 重量1,
max(case (px - 1)%4 when 1 then 箱号 end) 箱号2,
max(case (px - 1)%4 when 1 then 重量 end) 重量2,
max(case (px - 1)%4 when 2 then 箱号 end) 箱号3,
max(case (px - 1)%4 when 2 then 重量 end) 重量3,
max(case (px - 1)%4 when 3 then 箱号 end) 箱号4,
max(case (px - 1)%4 when 3 then 重量 end) 重量4
from
(
select * , px = (select count(1) from tb where 货号 = t.货号 and 颜色 = t.颜色 and 箱号 < t.箱号) + 1 from tb t
) m
group by 货号 , 颜色 , (px - 1)/4
order by 货号 , 颜色

drop table tb

/*
货号 颜色 箱号1 重量1 箱号2 重量2 箱号3 重量3 箱号4 重量4
---------- ---------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- -----------
001 白色 6 45 NULL NULL NULL NULL NULL NULL
001 黑色 4 23 5 32 NULL NULL NULL NULL
001 红色 1 20 2 40 3 10 4 23
001 红色 5 32 6 45 NULL NULL NULL NULL
001 绿色 7 43 NULL NULL NULL NULL NULL NULL

(所影响的行数为 5 行)
*/
jinjazz 2009-03-17
  • 打赏
  • 举报
回复
但不知道你的箱号1这列的数据怎么来的,你的结果太乱了
jinjazz 2009-03-17
  • 打赏
  • 举报
回复
行列转换,搜索一大堆

22,181

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧