MySQL Order by 语句用法与优化详解
程序员文章站
2024-02-22 14:58:46
mysql order by keyword是用来给记录中的数据进行分类的。mysql order by keyword根据关键词分类order by keyword是用来...
mysql order by keyword是用来给记录中的数据进行分类的。
mysql order by keyword根据关键词分类
order by keyword是用来给记录中的数据进行分类的。
复制代码 代码如下:
select column_name(s)
from table_name
order by column_name
例子
sql创建代码:
复制代码 代码如下:
create table if not exists mysql_order_by_test (
uid int(10) not null auto_increment,
name char(80) not null,
sex tinyint(1) not null,
key uid (uid)
) engine=myisam default charset=utf8 auto_increment=4 ;
insert into mysql_order_by_test (uid, name, sex) values(1, 'www.jb51.net', 1);
insert into mysql_order_by_test (uid, name, sex) values(2, '李四', 2);
insert into mysql_order_by_test (uid, name, sex) values(3, '王二麻子', 1);
通过索引优化来实现mysql的order by语句优化:
1、order by的索引优化。如果一个sql语句形如:
复制代码 代码如下:
select [column1],[column2],…. from [table] order by [sort];
在[sort]这个栏位上建立索引就可以实现利用索引进行order by 优化。
2、where + order by的索引优化,形如:
复制代码 代码如下:
select [column1],[column2],…. from [table] where [columnx] = [value] order by [sort];
建立一个联合索引(columnx,sort)来实现order by 优化。
注意:如果columnx对应多个值,如下面语句就无法利用索引来实现order by的优化
复制代码 代码如下:
select [column1],[column2],…. from [table] where [columnx] in ([value1],[value2],…) order by[sort];
3、where+ 多个字段order by
复制代码 代码如下:
select * from [table] where uid=1 order x,y limit 0,10;
建立索引(uid,x,y)实现order by的优化,比建立(x,y,uid)索引效果要好得多
在某些情况中,mysql可以使用一个索引来满足order by子句,而不需要额外的排序。where条件和order by使用相同的索引,并且order by的顺序和索引顺序相同,并且order by的字段都是升序或者都是降序。
例如:下列sql可以使用索引。
复制代码 代码如下:
select * from t1 order by key_part1,key_part2,... ;
select * from t1 where key_part1=1 order by key_part1 desc, key_part2 desc;
select * from t1 order by key_part1 desc, key_part2 desc;
但是以下情况不使用索引:
复制代码 代码如下:
①select * from t1 order by key_part1 desc, key_part2 asc;
--order by的字段混合asc和desc
②select * from t1 where key2=constant order by key1;
--用于查询行的关键字与order by中所使用的不相同
③select * from t1 order by key1, key2;
--对不同的关键字使用order by:
上一篇: 如何配置全世界最小的 MySQL 服务器