热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

pl/sql过程分页显示小案例

pl/sql过程分页显示小案例编写一个过程,要求可以输入表名,输入每页显示的记录数,输入当前页,返回总记录数,总页数,和返回的结果集--------------------------------------------------...SyntaxHighlighter.all

pl/sql过程分页显示小案例
 
编写一个过程,要求可以输入表名,输入每页显示的记录数,输入当前页,返回总记录数,总页数,和返回的结果集
                    ---------------------------------------------------------------------  www.2cto.com  
                     SQL>create or replace package testPackage as type test_cursor(游标名) is ref cursor(游标)
                         end testPackage
                     SQL>create procedure p8(table_name in varchar2,--表名
                          pageSize in number,                       --当前显示的记录数
                          pageNow in number,--当前页
                                                                    --下面都是要返回的内容,其值在过程处理中赋予
                          myrows out number,                        --总记录数
                          myPageCount out number,                   --总页数
                          p_cursor out testPackage.test_cursor      --返回的结果集
                           ) is
                         --定义sql语句
                         v_sql varchar2(1000);
                       
                         v_begin number := (pageNow - 1)*pageSize + 1; -- 每页显示的最少数
                         v_end number := pageNow * pageSize;           --每页显示的最大数  www.2cto.com  
                         
                         bgein
                            v_sql := 'select * rownum from (SQL>select a1.*,rownum rn from (select name,sal from '||table_name||') 
                              a1 where rownum<=&#39;||v_end||&#39;) where  rownum>&#39;||v_begin||&#39;&#39;;
                            
                            open p_cursor for v_sql;                                --打开一个游标,将游标和sql语句关联起来
                            v_sql : = &#39;select  count(*) from &#39;||table_name&#39;&#39;;       --计算myrows和myPageCount         
                            execute immediate v_sql into  myrows ;                  --执行sql,并把返回值赋给myrows来记录总记录数
                           
                            if mod(myrows,pageSize)= 0 then                       --计算总页数,注意思路,很好理解
                               myPageCount := myrows/Pagesiez;
                            else 
                               myPageCount := myrows/Pagesiez + 1;
                            end if
                           
                            close p_cursor;                                         --关闭游标  www.2cto.com  
                         end;
                         /
                      ------------------------------------------------------------------------------------------------------
                      Class.forName("oracle.jdbc.driver.OracleDriver");
                      Connection ct = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:
                       
                     CallableStatement cs = ct.prepareCall("{call p8(?,?,?,?,?,?)}");
                     
                     //给?赋值
                     cs.setString(1,"myTable");
                     sc.setInt(2,5);
                     sc.setInt(3,1);
                     //给out参数?赋值
                     cs.registOutPrameter(4,oracle.jdbc.OracleTypes.INTEGER);//这侧记录总数
                     cs.registOutPrameter(5,oracle.jdbc.OracleTypes.INTEGER);//注册总页数
                     cs.registOutPrameter(6,oracle.jdbc.OracleTypes.CURSOR);//注册返回的结果集
  www.2cto.com  
                     //执行
                     cs.execute();
                     //得到结果集
                     ResultSet rs = (ResultSet) cs.getObject(6);
                     
                     //取出总记录数
                      int rowNum = cs.getInt(4);
                     //返回总页数
                     int pagecount = cs.getInt(5);
                     while(rs.next()){
                         System.out.println(rs.getInt(1) + "--" + rs.getString(2));
                     }
                    
                     //关闭相关资源,此处略写
 
作者 chunqiuwei

推荐阅读
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文介绍如何在 FireDAC 环境下实现 FDMEMTable 字段的自动获取,为开发人员提供便捷的数据处理方式。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 本文探讨了在Oracle数据库中,动态SQL语句的执行及其对事务管理的影响,特别是关于回滚操作的有效性。重点讨论了一个具体场景:将预警短信从当前表迁移到历史表时遇到的字段长度不匹配问题及相应的异常处理。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 本文将深入探讨使用IMPDP工具进行分区表导入时需要注意的事项,涵盖最佳实践和常见问题。通过详细的分析与解释,帮助读者更好地理解和应用这些知识。 ... [详细]
  • PostgreSQL 10 离线安装指南
    本文详细介绍了如何在无法联网的服务器上进行 PostgreSQL 10 的离线安装,并涵盖了从下载安装包到配置远程访问的完整步骤。 ... [详细]
  • 探讨如何使用正则表达式从类 SQL 查询语句中提取字段及其对应的值。 ... [详细]
  • TCP长连接设备管理平台:架构与功能概览
    本文介绍了基于TCP长连接的设备管理平台的设计理念、技术选型及主要功能模块。最初,项目旨在实现简单的协议测试,但随着需求扩展,逐步演变为一个完整的前后端分离系统。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 使用Pandas高效读取SQL脚本中的数据
    本文详细介绍了如何利用Pandas直接读取和解析SQL脚本,提供了一种高效的数据处理方法。该方法适用于各种数据库导出的SQL脚本,并且能够显著提升数据导入的速度和效率。 ... [详细]
  • 本文介绍了如何在 Oracle 数据库中结合使用 UPDATE 和 SELECT 语句,以实现复杂的数据更新操作。首先准备测试环境和数据表,然后通过嵌套查询的方式从其他表中获取需要更新的值,最后执行更新操作并验证结果。 ... [详细]
author-avatar
哈哈
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有