加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle读取评论列表,先按点赞次数取前三名,然后按创建时间倒序

发布时间:2020-12-12 15:31:37 所属栏目:百科 来源:网络整理
导读:oracle读取评论列表,先按点赞次数取前三名,然后按创建时间倒序排序,需要分页: 第一种方式: select * from (SELECT b.*,DECODE(rownum,1,2,3,4) rank FROM (SELECT a.* FROM ACT_COMMENT_INFO a order by a.prize_num desc,ref desc) b) c order by c.ra

oracle读取评论列表,先按点赞次数取前三名,然后按创建时间倒序排序,需要分页:

第一种方式:

select *

from (SELECT b.*,DECODE(rownum,1,2,3,4) rank
FROM (SELECT a.*
FROM ACT_COMMENT_INFO a
order by a.prize_num desc,ref desc) b) c

order by c.rank,c.ref desc;


第二种方式:

SELECT aa.*
FROM (

SELECT *
FROM (SELECT a.*,1 o
FROM ACT_COMMENT_INFO a
WHERE a.target_act_id = 24
ORDER BY a.prize_num DESC,ref desc)
WHERE rownum <= 3
UNION
SELECT *
FROM (SELECT b.*,2 o
FROM ACT_COMMENT_INFO b
WHERE b.target_act_id = 24
ORDER BY b.ref DESC)) aa
ORDER BY aa.o,aa.ref desc;


第二种方式可能出现重复数据。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读