MariaDB社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3003|回复: 6
打印 上一主题 下一主题

一个比较头痛的SQL,不知道怎么写

[复制链接]
跳转到指定楼层
1#
发表于 2011-7-11 11:51:06 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
表结构
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 一个,这个查询怎么写?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖 顶 踩
2#
发表于 2011-7-11 13:51:28 | 只看该作者
参考:
SELECT TIME,`type`,COUNT(*) FROM TestGroupBy GROUP BY `type` ORDER BY TIME DESC ,COUNT(*) DESC ;
3#
 楼主| 发表于 2011-7-12 16:37:06 | 只看该作者
楼上的说的跟我说的是两码事,我这里说的type是指,各个type值下的数据在数据库内有的数据总数都大于3条甚至更多,但是我只取type=3的3条排在前面,然后排type=2的2条跟着,接着排type=1的一条跟着,等所有type的排过一次后,再跟着排type=3的3条,接着type=2的2条,依次这样循环下去
4#
发表于 2011-7-13 11:16:12 | 只看该作者
分页还得排序,你小心你的性能。
5#
发表于 2011-7-13 11:23:24 | 只看该作者
思路,计算求和 排序,生成行号  翻页。
6#
发表于 2011-7-13 11:45:05 | 只看该作者
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
你看看这个行不
7#
发表于 2011-7-13 11:45:35 | 只看该作者
我没有进行测试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|手机版|MariaDB社区 ( 京ICP备07012489号    |
业务联系: QQ:48474881; 邮箱: 48474881@qq.com; 电话:13911732319
声明:本站部分文章是网友转载,若未经作者同意或署名有误,请联系网站管理员。

GMT+8, 2024-11-10 07:47 , Processed in 0.081027 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表