这条简单的mysql的排序怎么提高效率? [

WBOY
Lepaskan: 2016-06-23 13:38:31
asal
1123 orang telah melayarinya

select distinct A.name from table A order by (select sum(num) as num from table where name=A.name) desc

一个表table,name字段有重复,num字段是数字。。显示不重复的name,然后相同的name的num加总数量排序。。
上面这条SQL结果是正确的,就是非常慢。一万多条记录就很慢了,原因是在排序那里。。
请问怎么修改才能又快又达到这样的排序功能?


回复讨论(解决方案)

select name, sum(num) as xxx from table group by name order by xxx desc

统计是不会快的,增加一个冗余的统计表才是正道.

select name, sum(num) as xxx from table group by name order by xxx desc



谢谢,好用。。比原来快多了。。
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan