文档详情

Oracleg数据库基础教程基于Oracle数据库的应用开发.ppt

发布:2017-04-02约1.05万字共39页下载文档
文本预览下载声明
第17 基于Oracle数据库的应用开发 本章内容 利用PL/SQL程序实现分页查询 基于Oracle数据库的人事管理系统开发 本章要求 掌握利用PL/SQL程序实现分页查询 掌握利用JDBC连接数据库的方法 了解基于数据库的应用系统开发过程 了解人事管理系统部分核心代码的实现 17.1 利用PL/SQL实现分页查询 利用集合实现分页查询 利用游标变量实现分页查询 分页查询在Java开发中的应用 17.1.1 利用集合实现分页查询 如果要对特定结构的结果集进行分页查询,则可以使用集合实现。 利用分页查询实现对员工工资名次、员工号、员工名、工资和部门号的查询。 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_pageSize IN OUT INT, --每页输出的记录数 p_curPageNo IN OUT INT, --当前页码 p_outCollection OUT emplist --查询返回当前页数据的集合 ); END; CREATE OR REPLACE PACKAGE BODY emppkg IS PROCEDURE sp_page( p_pageSize IN OUT INT, --每页输出的记录数 p_curPageNo IN OUT INT, --当前页码 p_outCollection OUT emplist) --查询返回当前页数据的集合 AS v_startRownum NUMBER; v_endRownum NUMBER; v_totalRecords NUMBER; v_totalPages NUMBER; indexValue BINARY_INTEGER :=1; BEGIN --查询记录总数 SELECT count(*) INTO v_totalRecords FROM emp; --验证页面记录数量 IF p_pageSize 0 THEN p_pageSize := 10; END IF; --计算总页数 IF MOD(v_totalRecords,p_pageSize)=0 THEN v_totalPages:=v_totalRecords/p_pageSize; ELSE v_totalPages:=floor(v_totalRecords/p_pageSize)+1; END IF; --验证页号 IF p_curPageNo 1 THEN p_curPageNo := 1; END IF; IF p_curPageNov_totalPages THEN p_curPageNo :=v_totalPages; END IF; --执行分页查询 v_startRownum := (p_curPageNo-1)*p_pageSize + 1; v_endRownum := p_curPageNo * p_pageSize; 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)
显示全部
相似文档