查看完整版本: 关于排名次的SQL难题

剑心 2006-3-15 16:08

关于排名次的SQL难题

一张表内有一个字段a,记录了从0-100的整数,现要根据a来排名次。  
注意:如果数值相同的,应该是相同的名次。  

如:  

id        a  
1          2  
2          5  
3          5  
4          6  
5          3  

排名次的结果应该是  

名次    id    a  
1          4      6  
2          2      5  
2          3      5  
4          5      3  
5          1      2  

这样的SQL语句怎么写最好呢?最好用mysql语法

liuzhusuoai 2006-3-15 16:10

这个问题的确有难度,  
1、需要产生递增的编号用来表示名次  
2、相同的数值要有相同的名次  
3、本来一个select  *  from  table  order  by  a  desc取出后用程序循环产生名次即可。但楼主要求使用mysql语句完成  

MYSQL:先建表、插入数据  
CREATE  TABLE  test4  (  
   id  tinyint(4)  NOT  NULL  auto_increment,  
   a  tinyint(4)  NOT  NULL  default  '0',  
   UNIQUE  KEY  id  (id)  
)  TYPE=MyISAM;  

INSERT  INTO  test4  VALUES  (1,  2);  
INSERT  INTO  test4  VALUES  (2,  6);  
INSERT  INTO  test4  VALUES  (3,  4);  
INSERT  INTO  test4  VALUES  (4,  9);  
INSERT  INTO  test4  VALUES  (5,  5);  
INSERT  INTO  test4  VALUES  (6,  0);  
INSERT  INTO  test4  VALUES  (7,  6);  
INSERT  INTO  test4  VALUES  (8,  5);  
INSERT  INTO  test4  VALUES  (9,  0);  

DROP  TABLE  testtemp;  #  删除临时表  
CREATE  TABLE  testtemp  (  #  创建临时表  
   id  tinyint(4)  NOT  NULL  auto_increment,  
   a  tinyint(4)  NOT  NULL  default  '0',  
   UNIQUE  KEY  id  (id)  
)  TYPE=MyISAM;  
insert  into  testtemp  select  DISTINCT  '',a  from  test4  order  by  a  desc;  #  向临时表插入不重复数据数据,利用自增字段产生编号  
select  b.id  as  level,a.id,a.a  from  test4  a,testtemp  b  where  a.a=b.a;  #  连接两表产生输出  

PHP:  
<?php  
$sql  =  array(  
"DROP  TABLE  testtemp",  
"CREATE  TABLE  testtemp  (  
   id  tinyint(4)  NOT  NULL  auto_increment,  
   a  tinyint(4)  NOT  NULL  default  '0',  
   UNIQUE  KEY  id  (id)  
)  TYPE=MyISAM;  
",  
"insert  into  testtemp  select  DISTINCT  '',a  from  test4  order  by  a  desc",  
"select  b.id  as  level,a.id,a.a  from  test4  a,testtemp  b  where  a.a=b.a"  
);  

$conn  =  mysql_connect();  
mysql_select_db("test");  

foreach($sql  as  $v)  
   $rs  =  mysql_query($v);  
mysql_result_all($rs);  

/**  仿odbc_result_all函数  **/  
function  mysql_result_all($result,$format="")  {  
   echo  "<table  $format><tr>";  
   for($i=0;$i<mysql_num_fields($result);$i++)  {  
       echo  "<th>".mysql_field_name($result,$i)."</th>";  
   }  
   echo  "</tr>";  
   while($row  =  mysql_fetch_row($result))  {  
       echo  "</tr>";  
       for($i=0;$i<mysql_num_fields($result);$i++)  {  
           echo  "<td>".$row[$i]."</td>";  
       }  
       echo  "</tr>";  
   }  
   echo  "</table>";  
}  

?>  

输出结果:  
level  id  a   
       1    4  9   
       2    2  6   
       2    7  6   
       3    5  5   
       3    8  5   
       4    3  4   
       5    1  2   
       6    6  0   
       6    9  0
页: [1]
查看完整版本: 关于排名次的SQL难题