当前位置:首页 > Mysql教程 > 列表

sql分组取最大记录方法

发布:smiling 来源: PHP粉丝网  添加日期:2014-10-14 13:31:20 浏览: 评论:0 

要想取利用group by 分组后第一条记录我们就需要结合order by 来操作,原是是很利用group by 把所有分组取出来,然后来利用order by 对分组里面的数据进行desc排序取第一条就KO了.

先看看group by 语句的用法

GROUP BY 语句,GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组.

SQL GROUP BY 语法,代码如下:

  1. SELECT column_name, aggregate_function(column_name) 
  2. FROM table_name 
  3. WHERE column_name operator value 
  4. GROUP BY column_name 

在SQL的 语句一起使用同样数目的SQL聚合函数提供分组的某些数据库教程表列,第结果数据集方法,实例,以下是 test 表,测试sql,代码如下:

  1. CREATE TABLE IF NOT EXISTS `test` ( 
  2. `id` int(10) unsigned NOT NULL auto_increment, 
  3. `install` int(10) unsigned NOT NULL
  4. `dayint(10) unsigned NOT NULL
  5. `aid` int(10) unsigned NOT NULL
  6. PRIMARY KEY (`id`) 
  7. ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=12 ; 
  8.  
  9. INSERT INTO `test` (`id`, `install`, `day`, `aid`) VALUES 
  10. (1, 'www.phpfensi.com', 20120308, 1), 
  11. (2, 2321, 20120309, 2), 
  12. (3, 1236, 20120310, 3), 
  13. (5, 'www.phpfensi.com', 20120309, 1), 
  14. (6, 2312, 20120310, 1), 
  15. (7, 1432, 20120311, 1), 
  16. (8, 2421, 20120308, 2), 
  17. (9, 4245, 20120311, 2), 
  18. (10, 'www.phpfensi.com', 20120310, 2), 
  19. (11, 412, 20120308, 3); 

实现sql语句,代码如下:

  1. SELECT A.* FROM test A, 
  2. (SELECT aid, MAX(day) max_day FROM test GROUP BY aid) B 
  3. WHERE A.aid = B.aid AND A.day = B.max_day 
  4. ORDER BY a.install DESC 

这样我们只要取集合的还desc排序的第一条就可以了.

再看个mssql server实例,例如 table1(a,b,c,d),代码如下:

  1. a    b    c    d 
  2. 1    0    c1  d1 
  3. 1    1    c2  d2 
  4. 1    3    c3  d3 
  5.  
  6. 4    0    c4  d4 
  7.  
  8. 5     1   c5   d5 
  9. 5     2   c6   d6 
  10.  
  11. 6     1   c7   d7 
  12. 6     4   c8   d8 

我要得到的是按a分组,在每个分组中取b值最大的一条记录,就是如下:

  1. a   b   c   d 
  2. 1   3   c3   d3 
  3. 4   0   c4   d4 
  4. 5   2   c6   d6 
  5. 6   4   c8   d8  

方法一,代码如下:

select * from table1 where b in (select max(b) from table1 group by a) ;

方法二,代码如下:

select * from table1 a where b=(select max(b) from table1 where a=a.a)

好了就讲这么多了,希望对大家有用.

Tags: sql分组 sql取最大记录

分享到: