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] Top K Frequent Words 前K个高频词
Given a non-empty list of words, return the k most frequent elements. Your answer should be sorted b ...
- 解决有关flask-socketio中服务端和客户端回调函数callback参数的问题(全网最全)
由于工作当中需要用的flask_socketio,所以自己学习了一下如何使用,查阅了有关文档,当看到回调函数callback的时候,发现文档里都描述的不太清楚,最后终于琢磨出来了,分享给有需要的朋友 ...
- 小白学习java设计模式之策略模式
策略模式:1.分析项目中的变化部分与不变部分(每个设计模式都要分析的)2.多用组合少用继承;用行为类组合,而不是行为继承,更具有弹性直接上代码: package com.wz.oneStrategis ...
- Python super使用
一 基础使用 在类的继承中,如果重定义某个方法,该方法会覆盖父类的同名方法,但有时,我们希望能同时实现父类的功能,这时,我们就需要调用父类的方法了,可通过使用 super 来实现,比如: #!/usr ...
- [ZJOI 2010]base 基站选址
Description 题库链接 给出 \(n\) 个村庄的横坐标 \(D_i\) .要求在这 \(n\) 个村庄内最多选择 \(m\) 个作为通讯基站,在村庄 \(i\) 建造通讯基站的代价为 \( ...
- 绝世好题bzoj4300
Description 给定一个长度为n的数列ai,求ai的子序列bi的最长长度,满足bi&bi-1!=0(2<=i<=len). Input 输入文件共2行. 第一行包括一个整数 ...
- ●洛谷P2934 [USACO09JAN]安全出行Safe Travel
题链: https://www.luogu.org/problemnew/show/P2934 题解: 最短路(树),可并堆(左偏堆),并查集. 个人感觉很好的一个题. 由于题目已经明确说明:从1点到 ...
- 【NOIP2012TG】solution
D1T1(Vigenere) 题意:给你一个原串与一个密码串,问你按照题意规则加密后的密文. 解题思路:暴力模拟. #include <stdio.h> ],c[],u1[],u2[]; ...
- [HZOI 2016]公路修建
[题目描述] OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多.然而,由于该岛屿刚刚开发不久,所以那里的交通情况还是很糟糕.所以,OIER Association组织成立了,旨 ...
- 习题9-4 uva 1630
题意: 给你一串数字,要求你对其进行折叠使其长度最短. 折叠情况:全是一个字母 & 重复的字符串 AAAAAAAAAABABABCCD --> 9(A)3(AB)CCD NEE ...