zhulichun8989 2014-11-17 01:10 采纳率: 0%
浏览 2371
已采纳

sql server 2008分组后如何实现分页查询

我的SQL语句是这样的
select left(loginDate,10) ,skipUrl,count(loginDate) FROM loginlog group by skipUrl,left(loginDate,10) order by left(loginDate,10) desc
我自己试了很多总方式都不对的,不知道问题出在哪里的了?希望大侠帮忙解决下的了谢谢!
select top 10 left(loginDate,10) ,skipUrl,count(loginDate)from loginlog
where not exists(select top 20 left(loginDate,10) ,skipUrl,count(loginDate) FROM loginlog group by skipUrl,left(loginDate,10) order by left(loginDate,10) desc )
group by skipUrl,left(loginDate,10) order by left(loginDate,10) desc
执行结果是没有数据的,可数据库中有数据的。

  • 写回答

2条回答 默认 最新

  • --小F-- 2014-11-17 16:29
    关注

    既然是 2008 用公用表达式配合 ROW_NUMBER()OVER()比较好
    ;with cte as
    (
    select left(loginDate,10) as loginDate ,skipUrl,count(loginDate) as loginDatenum FROM loginlog group by skipUrl,left(loginDate,10)
    )
    ,cte1 as
    (
    select id=row_number()over(partition by loginDate,skipUrl order by loginDate desc),* from cte
    )

    select loginDate,skipUrl ,loginDatenum from cte1 where id between 10 and 20

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部