程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> 數據庫-sql語句按年怎樣分組 求大神支招

數據庫-sql語句按年怎樣分組 求大神支招

編輯:編程綜合問答
sql語句按年怎樣分組 求大神支招

比如下面:
比如字段兩列
A B
2011 100
2011 60
2011 70
2012 200
2012 250
2013 300
2013 400

我想最後得到分組結果 比如:
2011年的為一個數組 array(
2011 => 100,
2011 => 60,
2011 => 70,


然後 2012和2013 和2011 一個道理
求大神支招

最佳回答:


--> 測試數據:[tb]
if object_id('[tb]') is not null drop table [tb]
go
create table tb
insert [tb]
select 2011,100 union all
select 2011,60 union all
select 2011,70 union all
select 2012,200 union all
select 2012,250 union all
select 2013,300 union all
select 2013,400
--------------開始查詢--------------------------
;with f as
(select id=row_number()over(order by getdate()),* from tb)

SELECT A.A,A.B,B.PX FROM F AS A
INNER JOIN
(
SELECT ROW_NUMBER()OVER( ORDER BY MIN(ID)) AS PX ,a FROM f GROUP BY a
) AS B
ON A.A=B.A
----------------結果----------------------------
/* A B PX


2011 100 1
2011 60 1
2011 70 1
2012 200 2
2012 250 2
2013 300 3
2013 400 3
*/

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved