一个比较头痛的SQL,不知道怎么写
表结构id
title
content
type
time
要达到的目的:每页显示10个,排序按照type和time排序,time 直接order by desc 但在type上有要求,比如现在数据库内type有1-3,那么排序应该是 type 3 3个,type 2 2个 ,type 1 一个 然后继续下来的是 type3 3个,type2 2个,type 1 一个,这个查询怎么写? 参考:
SELECT TIME,`type`,COUNT(*) FROM TestGroupBy GROUP BY `type` ORDER BY TIME DESC ,COUNT(*) DESC ;
楼上的说的跟我说的是两码事,我这里说的type是指,各个type值下的数据在数据库内有的数据总数都大于3条甚至更多,但是我只取type=3的3条排在前面,然后排type=2的2条跟着,接着排type=1的一条跟着,等所有type的排过一次后,再跟着排type=3的3条,接着type=2的2条,依次这样循环下去
分页还得排序,你小心你的性能。 思路,计算求和 排序,生成行号翻页。 select * from table1 inner join
(select type ,count(*) as c1 from table1 group by type ) as table2
on table1.type = table2.type order by c1 desc ,time desc
limit 0,10
你看看这个行不 我没有进行测试。
页:
[1]