需要用row_number来给分组添加序号。
1、创建测试表,插入数据:
create table test(sid int,sname varchar(20),sclass varchar(20),score int) insert into test values (1,'张三','一年一班',100)insert into test values (2,'李四','一年一班',78)insert into test values (3,'王五','一年一班',67)insert into test values (4,'赵六','一年一班',87)insert into test values (5,'badkano','一年二班',98)insert into test values (6,'百度知道团长','一年二班',99)insert into test values (7,'du小小动','一年二班',99)insert into test values (8,'刘备','一年三班',56)insert into test values (9,'张飞','一年三班',67)insert into test values (10,'关羽','一年三班',76)
2、要求按照班级总分给出班级排名(即序号),执行语句:
1select row_number() over (order by score desc) 排名,sclass 班级,score 总分 from (select sclass,SUM(score) score from test group by sclass) t3、查询结果:
1. 直接在程序中实现;这应该算是效率最高的一种,也极为方便。直接在你的开发程序中(PHP/ASP/C/...)等中,直接初始化一个变量nRowNum=0,然后在while 记录集时,nRowNum++然后输出即可。
2. 使用MySQL变量;在某些情况下,无法通过修改程序来实现时,可以考虑这种方法。
缺点,@x 变量是 connection 级的,再次查询的时候需要初始化。一般来说PHP等B/S应用没有这个问题。但C/S如果connection一只保持则要考虑 set @x=0
mysql>select @x:=ifnull(@x,0)+1 as rownum,id,col
->from tbl
->order by col
+--------+----+------+
| rownum | id | col |
+--------+----+------+
| 1 | 1 | 26 |
| 1 | 3 | 35 |
| 1 | 2 | 46 |
| 1 | 4 | 68 |
| 1 | 6 | 92 |
| 1 | 5 | 93 |
+--------+----+------+
6 rows in set (0.00 sec)
3. 使用联接查询(笛卡尔积)
缺点,显然效率会差一些。
利用表的自联接,代码如下,你可以直接试一下 select a.*,b.* from tbl a,tbl b where a.col>=b.col 以理解这个方法原理。
mysql>select a.id,a.col,count(*) as rownum
->from tbl a,tbl b
->where a.col>=b.col
->group by a.id,a.col
+----+------+--------+
| id | col | rownum |
+----+------+--------+
| 1 | 26 | 1 |
| 2 | 46 | 3 |
| 3 | 35 | 2 |
| 4 | 68 | 4 |
| 5 | 93 | 6 |
| 6 | 92 | 5 |
+----+------+--------+
6 rows in set (0.00 sec)
4. 子查询
缺点,和联接查询一样,具体的效率要看索引的配置和MySQL的优化结果。
mysql>select a.*,
-> (select count(*) from tbl where col<=a.col) as rownum
->from tbl a
+----+------+--------+
| id | col | rownum |
+----+------+--------+
| 1 | 26 | 1 |
| 2 | 46 | 3 |
| 3 | 35 | 2 |
| 4 | 68 | 4 |
| 5 | 93 | 6 |
| 6 | 92 | 5 |
+----+------+--------+
6 rows in set (0.06 sec)
做为一款开源的数据库系统,MySQL无疑是一个不做的产品。它的更新速度,文档维护都不逊于几大商业数据库产品。估计在下一个版本中,我们可以看到由MySQL自身实现的ROWNUM。
$Data=mysqli_fetch_assoc($Result)改为
$Data=mysqli_fetch_array($Result,MYSQLI_NUM)
即可用序号来获取记录值。请注意,由于序号是从0起算的,所以要想获得$Data中的第3个值,必须用$v=Data[2]
另外还可以用 $Data=mysqli_fetch_array($Result,MYSQLI_BOTH),这个时候,既可以用序号获取记录值,也可以用字段名
其实吧,你也可以通过循环对数组$Data进行遍历,不也可以在不知道字段名的情况下把所有值取出来啊?!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)