作者cutekid (可爱小孩子)
看板Database
标题Re: [SQL ] 关於 再排序 与 效率 的问题
时间Mon Nov 25 09:41:53 2013
SELECT Table_log.uid, Table_sex.sex, COUNT(*)
FROM Table_log, Table_sex
WHERE (date_time >= 20131105 AND date_time <= 20131107 AND
Table_log.uid = Table_sex.uid)
GROUP by Table_log.uid
ORDER BY Table_sex.sex,COUNT(*) DESC
LIMIT 100
※ 引述《vvrr (vvrr)》之铭言:
: ※ 引述《rockchangnew (rock)》之铭言:
: 原本打算周五晚上回覆的,结果跑去赶别的东西,
: 到刚才要睡了才想到……
: : 为何不将
: : order by count(*) desc 换成
: : order by count(*) desc,sex
: 这样的话,会变成「先排count,如果count相同的话再排sex」,
: 但是由於输出的结果想变成男生女生分开,所以我希望的是「完全照sex排」。
: 後来的写法是:
: SELECT * FROM (
: SELECT Table_log.uid, Table_sex.sex, COUNT(*)
: FROM Table_log, Table_sex
: WHERE (date_time >= 20131105 AND date_time <= 20131107 AND
: Table_log.uid = Table_sex.uid)
: GROUP by Table_log.uid
: ORDER BY COUNT(*) DESC
: LIMIT 100
: } as _tmp
: ORDER BY sex;
: 看起来是用了暂存表格的方法,暂时解决了。
: 因为资料很多,而且会一直成长,
: 如果有其他不用子查询又不用建暂存表格的方法还请大家不吝告知。
: 谢谢有回文推文和水球我的各位 <(_ _)>
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 1.168.101.73
1F:→ vvrr:这样是将全部资料先照男女排,再各自按count排序 11/25 15:57
2F:→ vvrr:取前100名的结果会变成「取到男生(或女生)最多的100名」 11/25 15:58
3F:→ vvrr:和我希望的「将前100名按男女分开」不一样...... 11/25 15:59
4F:→ cutekid:您好,可以举出一个您的写法跟上面写法不一样的例子吗 3Q 11/25 16:51
5F:→ vvrr:假设100男100女,count各自都是从1~100 11/25 17:00
6F:→ vvrr:我希望拿到的是「男100~男51, 女100~女51」共100名 11/25 17:00
7F:→ vvrr:你的写法会找到「男100~男1」或是「女100~女1」(看男女哪个先 11/25 17:01
8F:→ cutekid:假设: 100 男 count 都是 2;100 女 count 都是 1 11/25 18:27
9F:→ cutekid:您的写法,会得到您想要的答案吗 11/25 18:28
10F:→ vvrr:应该会拿到100个男生,也是我想要的答案 11/26 11:55