- 1、本文档共39页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Oracleg数据库基础教程基于Oracle数据库的应用开发
第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)
文档评论(0)