关于SQL的问题,求问一下SQL数据库分页原理?

sql数据库是怎么样分页的? 分页的SQL语句怎样写?

慕莱坞森
浏览 419回答 3
3回答

幕布斯7119047

要想分页,首先得做好准备工作。你要先声明每页显示多少条数据,还得获取当前选择的是多少页的页码。有了这两个分页就好办了。sql如下:select top 10 from tableNamewhere (id not in(select top 20 from tableName order by Id desc)) order by Id desc每页显示的数量:自己定义。总页数:数据总条数/每页显示的条数当前页码的计算方法:(页码-1)*每页显示的数量。比如我要浏览第3页的数据,3从客户端传送过来后,在后台对页码进行处理:(3-1)*每页显示的数量(假如是10).算出来后的结果就是20.你在把20以参数注入的方式动态添加到上面那个20那里就ok了。sql中的10表示你每页显示的数据,这里跟10,就代表每页显示10条。(你可以定义一个常量作为每页显示的条数)where中的20表示不包括前面的20条数据,也就是查询出从第21条到30之间的数据。不知道我这样说你是否理解,其实只要理解了sql语句,分页就很好做了。

沧海一幻觉

利用SQL语句分页要看你用的什么数据库。Oracle数据库可以使用ROWNUM或row_number(),例如:Select * from (select ROWNUM rn, t.* from table t) where rn between 11 and 20;Select * from (select row_number() over (ORDER BY col1) rn, t.* from table t) where rn between 11 and 20;SQLServer数据库可以用Top或者row_number()函数,道理同上。利用SQL分页有局限性,就是针对不同的数据库有不同的写法,所以通常会在应用程序里面做分页通用性比较强。但是对于数据量非常庞大的应用来说,还是用SQL分页比较适合。
打开App,查看更多内容
随时随地看视频慕课网APP