当前位置: 代码迷 >> Sql Server >> 请教,小弟我想select Fd1,Fd2 但又只想Group By Fd2该如何写(Fd1只要第一个记录的值就行)多谢
  详细解决方案

请教,小弟我想select Fd1,Fd2 但又只想Group By Fd2该如何写(Fd1只要第一个记录的值就行)多谢

热度:7   发布时间:2016-04-24 18:17:32.0
请问,我想select Fd1,Fd2 但又只想Group By Fd2该怎么写(Fd1只要第一个记录的值就行)谢谢!
请问,我想select Fd1,Fd2  但又只想Group By Fd2该怎么写(Fd1只要第一个记录的值就行)谢谢!
------解决方案--------------------
select max(fd1),fd2 XXXX group by fd2
------解决方案--------------------
第一个记录的概念是不稳定的,可以用最大或最小的 fd1,就像1楼写的。
------解决方案--------------------

楼主你是想按照某个列汇总另外一个列,同时查询其他的列吧
推荐窗口函数,用起来贼爽

create table #t
(
column1 int,
column2 int,
column3 int,
column4 int

)

insert into #t values (1,RAND()*100,RAND()*100,RAND()*100)
insert into #t values (2,RAND()*100,RAND()*100,RAND()*100)
insert into #t values (2,RAND()*100,RAND()*100,RAND()*100)
insert into #t values (3,RAND()*100,RAND()*100,RAND()*100)
insert into #t values (4,RAND()*100,RAND()*100,RAND()*100)

select column1,SUM(column2)over (partition by column1),column3,column4 from #t

------解决方案--------------------
建议用开窗函数 
例如:

select orderid,custid,val, 
SUM(val) over() as totalValue,  --不分区 sum(val)为val的总和
SUM(val) over(partition by custid) as custtotalvalue  --partition by custid 按照custid分区, sum(val)为一个custid的总和
from Sales.OrderValues

--partition by custid 按照custid分区

--结果

  相关解决方案