日期:2014-05-16  浏览次数:20740 次

请教MYSQL高手:MYSQL中如何实现分组排序并追加新行号
描述如下:
  数据库表ss 包含四个字段,staticttime,ip1,ip2,amount
  SQL Server2005中存在如下SQL语句:
  select row_number() over (PARTITION by b.ip1,b.ip2 order by sum(b.amount) desc) as row_num,b.ip1 from ss;
  但是MYSQL不支持row_number() over 函数,请问在MYSQL中有什么方法可实现上述功能,并且效率较高。
 

------解决方案--------------------
http://blog.csdn.net/acmain_chm/article/details/4095531
MySQL 几乎模拟了 Oracle,SQL Server等商业数据库的大部分功能,函数。但很可惜,到目前的版本(5.1.33)为止,仍没有实现ROWNUM这个功能。 下面介绍几种具体的实现方法.建立实验环境如下mysql> create table tbl ( -> id int primary key, -> col int -> );Que...
------解决方案--------------------
没这个现成的函数 你可以把结果集导入到有自增id的表中来实现