oracle sql语句获取前两条数据
selectid,seqfromhzds_adminwhereseq<=(selectseqfromhzds_adminwhereid=42)andparid=0orde...
select id,seq from hzds_admin where seq<=(select seq from hzds_admin where id=42) and parid=0 order by seq desc limit 0,2,这个sql是mysql的,我想换成oracle的,好像oracle没有limit 0,2这个的,求大神帮忙改下,谢谢了
展开
展开全部
select * from (select id,seq from hzds_admin where seq<=(select seq from hzds_admin where id=42) and parid=0 order by seq desc) where rownum<3
更多追问追答
追问
这个rownum到底是什么意思,如果我要做分页的话,这个是怎么来做的
追答
rownum是行号的意思,是oracle的一个隐含列,不过这个不能作为分页,因为rownum每次都是从0开始的,也就是说,你不能用rownum >10,这样的语句,因为这样查出来是空值。
如果要分页,那么你就把rownum这个函数写到语句中并重命名为a,也就是类似
select rownum a,其他字段名 from (select id,seq from hzds_admin where seq0 and a<20
还有一种方式,就是利用row_number over这样的开窗函数进行编号,然后再循环也行。具体的写法,网上太多了,稍微查查就有不少,我就不写了。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询