PLSQL实现分页查询
--集合实现游标查询 CREATE OR REPLACE PACKAGE emppkg IS TYPE t_record IS RECORD( rn INT, empno emp.empno%TYPE, ename emp.ename%TYPE, sal emp.sal%TYPE, deptno emp.deptno%TYPE); TYPE emplist IS TABLE OF t_record;--定义返回结果的记录集合类型 --定义实现分页显示的过程 PROCEDURE sp_page( p_page_size IN OUT INT,--每页输出显示的记录数 p_cur_page_no IN OUT INT,--当前页码 p_outcollection OUT emplist--接收查询返回结果 ); END emppkg; / CREATE OR REPLACE PACKAGE BODY emppkg IS PROCEDURE sp_page( p_page_size IN OUT INT,--每页输出记录数 p_cur_page_no IN OUT INT,--当前页码 p_outcollection OUT emplist--接收查询返回值 ) IS v_start_rownum NUMBER; v_end_rownum NUMBER; v_total_records NUMBER; v_total_pages NUMBER; indexvalue BINARY_INTEGER :=1; BEGIN --查询记录总数 SELECT COUNT(*) INTO v_total_records FROM emp; --验证输入页面显示记录数量,确保大于0 IF p_page_size < 0 THEN p_page_size :=10; END IF; --计算页面总数 IF MOD(v_total_records,v_total_pages) = 0 THEN v_total_pages := v_total_records / p_page_size; ELSE v_total_pages := (v_total_records / p_page_size)+1; END IF; --验证页号 IF p_cur_page_no < 1 THEN p_cur_page_no := 1; END IF; IF p_cur_page_no > v_total_pages THEN p_cur_page_no := v_total_pages; END IF; --执行分页查询 --计算当前页开始显示的记录在整个记录中从哪开始 v_start_rownum := (p_cur_page_no-1)*p_page_size+1; --计算当前页的最后一条记录位于哪 v_end_rownum := p_cur_page_no*p_page_size; --构造初始化记录嵌套表 p_outcollection := emplist(); --查询记录 FOR v_emp IN (SELECT * FROM (SELECT ROWNUM rn,empno,ename,sal,deptno FROM (SELECT empno,ename,sal,deptno FROM emp WHERE sal IS NOT NULL ORDER BY sal) A--选出有sal的作为表A WHERE ROWNUM<=v_end_rownum) B WHERE rn>=v_start_rownum)--在B中筛选去掉当前页之前的所有记录 LOOP--循环把取出的数赋给接收变量 p_outcollection.EXTEND; p_outcollection(indexvalue):=v_emp; indexvalue:=indexvalue+1; END LOOP; END sp_page; END emppkg; / --游标实现分页查询 CREATE OR REPLACE PACKAGE curspkg IS TYPE query_cursor IS REF CURSOR; PROCEDURE sp_page( p_page_size IN OUT INT,--每页输出记录数 p_cur_page_no IN OUT INT,--当前页码 p_sql_select VARCHAR2,--查询语句,包含排序部分 p_total_pages OUT INT,--返回总页数 p_total_records OUT INT,--返回总记录数 p_out_cursor OUT query_cursor--接收返回当前页的数据集 ); END curspkg; / CREATE OR REPLACE PACKAGE BODY curspkg IS PROCEDURE sp_page( p_page_size IN OUT INT,--每页输出记录数 p_cur_page_no IN OUT INT,--当前页码 p_sql_select VARCHAR2,--查询语句,包含排序部分 p_total_pages OUT INT,--返回总页数 p_total_records OUT INT,--返回总记录数 p_out_cursor OUT query_cursor--接收返回当前页的数据集 ) IS v_count_sql VARCHAR2(1000); v_start_rownum INT; v_end_rownum INT; v_sql VARCHAR2(4000); BEGIN --动态sql语句,调用输入的查询语句,计算输入的语句一共查询出多少数据 v_count_sql := 'SELECT TO_CHAR(COUNT(*)) FROM ('||p_sql_select||')'; EXECUTE IMMEDIATE v_count_sql INTO p_total_records; --验证输入页面显示记录数量,确保大于0 IF p_page_size < 0 THEN p_page_size :=10; END IF; --计算页面总数 IF MOD(p_total_records,P_total_pages) = 0 THEN P_total_pages := p_total_records / p_page_size; ELSE P_total_pages := (p_total_records / p_page_size)+1; END IF; --验证页号 IF p_cur_page_no < 1 THEN p_cur_page_no := 1; END IF; IF p_cur_page_no > P_total_pages THEN p_cur_page_no := P_total_pages; END IF; --执行分页查询 --计算当前页开始显示的记录在整个记录中从哪开始 v_start_rownum := (p_cur_page_no-1)*p_page_size+1; --计算当前页的最后一条记录位于哪 v_end_rownum := p_cur_page_no*p_page_size; v_sql:='SELECT * FROM (SELECT ROWNUM rn,A.* FROM ('||p_sql_select||') A WHERE ROWNUM<='||TO_CHAR(v_start_rownum)||') B WHERE rn>='||TO_CHAR(v_end_rownum); OPEN p_out_cursor FOR v_sql; END sp_page; END curspkg; /
PLSQL实现分页查询的更多相关文章
- JdbcTemplate+PageImpl实现多表分页查询
一.基础实体 @MappedSuperclass public abstract class AbsIdEntity implements Serializable { private static ...
- 用Hibernate和Struts2+jsp实现分页查询、修改删除
1.首先用get的方法传递一个页数过去 2.通过Struts2跳转到Action 3.通过request接受主页面index传过的页数,此时页数是1, 然后调用service层的方法获取DAO层分页查 ...
- MySQL、Oracle和SQL Server的分页查询语句
假设当前是第PageNo页,每页有PageSize条记录,现在分别用Mysql.Oracle和SQL Server分页查询student表. 1.Mysql的分页查询: SELECT * FROM s ...
- 分页查询和分页缓存查询,List<Map<String, Object>>遍历和Map遍历
分页查询 String sql = "返回所有符合条件记录的待分页SQL语句"; int start = (page - 1) * limit + 1; int end = pag ...
- mysql 分页查询
mysql,; : mysql,; -last. //如果只给定一个参数,它表示返回最大的记录行数目: mysql; 个记录行 ,n. 动态传参的分页查询 SELECT * FROM table LI ...
- MongoDB 分页查询的方法及性能
最近有点忙,本来有好多东西可以总结,Redis系列其实还应该有四.五.六...不过<Redis in Action>还没读完,等读完再来总结,不然太水,对不起读者. 自从上次Redis之后 ...
- .NET平台开源项目速览(7)关于NoSQL数据库LiteDB的分页查询解决过程
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑) 与 .NET平台开源项目速览(3)小巧轻量级NoSQL文件数据库LiteDB中,介绍了LiteDB的基本使用情况以及部 ...
- SubSonic3.0插件分页查询速度测试
使用SubSonic3.0一段时间了,一直都想找机会测试一下各种查询分页速度,对比一下插件的查询效率到底怎么样,所以昨天写好了测试程序,准备好1K.1W.10W.50W和100W记录的数据表,早上详细 ...
- Node.js、express、mongodb 实现分页查询、条件搜索
前言 在上一篇Node.js.express.mongodb 入门(基于easyui datagrid增删改查) 的基础上实现了分页查询.带条件搜索. 实现效果 1.列表第一页. 2.列表第二页 3. ...
随机推荐
- [LeetCode] Knight Probability in Chessboard 棋盘上骑士的可能性
On an NxN chessboard, a knight starts at the r-th row and c-th column and attempts to make exactly K ...
- [WC2006]水管局长数据加强版
Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一 ...
- 计蒜客NOIP模拟赛6 D1T1Diamond-square
Diamond-square 算法是一种能够用于生成噪声的算法,现在我们考虑这个算法的一个变种. 你有一个 2^n\times 2^n2n×2n 的网格,一共有 (2^n+1)^2(2n ...
- ●UOJ58 [WC2013]糖果公园
题链: http://uoj.ac/problem/58题解: 树上带修莫队. 每个块的大小为$n^{\frac{2}{3}}$,在dfs时,把点集分为若干块. 然后类似序列带修莫队,三个关键字:be ...
- C++Primer学习——类
我们在创建类的对象时,类不应该仅仅被声明,还应该被定义过,否则无法知道类占用了多少的内存 但是如果一个类的名字已经出现过就被认为是已经声明过了,所以允许包含自己的指针或者引用. 默认构造函数: 当类中 ...
- hdu 4747 线段树
Mex Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Submis ...
- PowerBI 第九篇:修改查询
在PowerBI的查询编辑器中,用户可以使用M语言修改Query,或修改Query字段的类型,或向Query中添加数据列(Column),对Query进行修改会导致PowerBI相应地更新数据模型(D ...
- 谈谈Python中的decorator装饰器,如何更优雅的重用代码
众所周知,Python本身有很多优雅的语法,让你能用一行代码写出其他语言很多行代码才能做的事情,比如: 最常用的迭代(eg: for i in range(1,10)), 列表生成式(eg: [ x* ...
- RESTful 最佳实战
在GitHub上看到一本不错的关于REST实战的书,很高兴分享阅读笔记.[下载地址] 一.什么是REST(WHAT) REST架构描述了六种约束.(统一接口.无状态.可缓存.CS架构.分层系统.按需编 ...
- ionic 禁用 手势 滑动返回
$ionicConfigProvider.views.swipeBackEnabled(false); 在 应用的 config里面 配置下 上面的那句话 就OK了.