您好,欢迎访问一九零五行业门户网

MySQL Order by 语句优化代码详解

order by语句是用来排序的,经常我们会使用到order by来进行排序,下面我给大家来讲讲order by用法与优化排序,有需要的同学可参考
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 order by 语句优化代码详解的详细内容。
其它类似信息

推荐信息