日期:2014-05-18  浏览次数:20763 次

SQL统计语句
表:
品名 型号 数量 检验结果 到货时间
主板 MS6714 200 合格 2005-10-9
主板 MS6368 1000 不合格 2005-9-4
主板 MS6714 50 合格 2005-12-6
显卡 7300SE 500 合格 2006-1-4
………………………………………………

sql="select 型号,sum(数量) as 合计 from 表 where 检验结果='合格' group by 型号 order by 型号"

查收到的这个记录集只有“型号”和对应的“合计”,而该型号对应的“品名”也要成为记录集的一部分,并且首先要按“品名”排序,再次型号排序。

语句要怎样改?
谢谢!

------解决方案--------------------
SQL code

这样?
select 品名,型号,sum(数量) as 合计 from kl where isnull(检验结果,'')= '合格' 
group by 型号,品名 order by 品名,型号

------解决方案--------------------
SELECT a.品名,a.型号,b.合计
FROM 表1 a RIGHT JOIN (select 型号,sum(数量) as 合计 from 表 where 检验结果= '合格 ' group by 型号) b ON a.型号=b.型号 
ORDER BY a.型号
------解决方案--------------------
create table lingyunbi
(
品名 char(50),
型号 char(50),
 数量 int,
检验结果 char(50),
 到货时间 char(50)
)
delete lingyunbi
insert into lingyunbi

select '主板', 'MS6714' , 200 , '合格' , '2005-10-9' union all 
select '主板' ,'MS6368' , 1000 , '不合格' , '2005-9-4' union all 
select '主板' , 'MS6714' , 50 , '合格' , '2005-12-6' union all 
select '显卡', '7300SE' , 500 , '合格' , ' 2006-1-4' union all 
select 'cpu', 'AMD' , 300 , '合格' , ' 2006-1-4' union all 
select 'cpu', 'Intel' , 800 , '合格' , ' 2006-1-4' 

select 品名, 型号 ,sum(数量) as 合计 from lingyunbi where 检验结果= '合格' group by 型号,品名 order by 品名 

------------------------
?? 7300SE 500
cpu AMD 300
cpu Intel 800
主板 MS6714 250