重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
首先你得告诉我,你的正序条件是什么!比如说你的正序条件是name这个字段,也就是说,name字段进行正序排列,如果name字段存储的数据分别为aaa,bbb,ccc。那么按照name字段正序排列的话sql语句就是这样的:select * from xxx order by name asc
创新互联公司专注于枣阳企业网站建设,响应式网站设计,电子商务商城网站建设。枣阳网站建设公司,为枣阳等地区提供建站服务。全流程按需网站设计,专业设计,全程项目跟踪,创新互联公司专业和态度为您提供的服务
如果按照name反向排列的话就是这样的:select * from xxx order by name desc
MySQL中排序输出需要用order by。
如图,test表中有如下数据:
现在分别要求按ID正序和倒序输出结果。
正序:
select * from test order by id;
结果:
倒序:
select * from test order by id desc;
结果:
2.1 排序方式
数据量小则在内存排序, 数据量大则使用磁盘排序
内存排序 : 直接使用"快速排序"
磁盘排序 : 先将数据分块, 对每个独立的块使用"快速排序", 并将各个块的排序结果存在磁盘上, 然后将各个排好序的块进行合并(merge), 最后返回排序结果
2.2 排序算法
3. 注意点 :
为这个问题 专门写了一个mysql function,实现的功能是,返回前几条记录。其实还可以在完善的,返回这些记录的数据的。
delimiter $$
drop function if exists top7$$
create function top7(num int(11))
returns int(11)
begin
declare totalPrice int;
declare i int;
declare countNum int;
declare tmp int;
select count(1) into countNum from mywcd;
set i=0;
set totalPrice=0;
set tmp=0;
tt:
while icountNum
do
set tmp=(select price from mywcdlimit i,1);
set i=i+1;
set totalPrice=totalPrice+tmp;
if totalPrice=num then
leave tt;
end if;
end while;
return i;
end;
$$
delimiter ;
mysql select * from mywcd;
+—-+——-+
| id | price |
+—-+——-+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
| 4 | 400 |
| 5 | 500 |
| 6 | 600 |
+—-+——-+
6 rows in set (0.00 sec)
这是我测试数据的表全部记录。
调用以及返回结果:
mysql select top7(1001);
+————+
| top7(1001) |
+————+
| 5 |
+————+
1 row in set (0.00 sec)