`

Oralce通用分页包

SQL 
阅读更多

CREATE OR REPLACE package p_page is
 type refCursorType is REF CURSOR;  --游标类型定义,用于返回数据集
 procedure sp_Page(p_PageSize int,          --每页记录数
                   p_PageNo int,            --当前页码,从 1 开始
                   p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_OutRecordCount out int,--返回总记录数
                   p_OutCursor out refCursorType);
 procedure sp_Page(p_PageSize int,          --每页记录数
                   p_PageNo int,            --当前页码,从 1 开始
                   p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_SqlCount varchar2,     --获取记录总数的查询语句
                   p_OutRecordCount out int,--返回总记录数
                   p_OutCursor out refCursorType);
 procedure sp_Page(p_PageSize int,        --每页记录数
                   p_PageNo int,          --当前页码,从 1 开始
                   p_SqlSelect varchar2,  --查询语句,含排序部分
                   p_OutCursor out refCursorType);
 procedure sp_Page(p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_OutRecordCount out int); --返回总记录数
 end p_page;
/

CREATE OR REPLACE PACKAGE BODY p_page as
 procedure sp_Page(p_PageSize int,          --每页记录数
                   p_PageNo int,            --当前页码,从 1 开始
                   p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_OutRecordCount out int,--返回总记录数
                   p_OutCursor out refCursorType)
 as
     v_sql varchar2(3000);
     v_count int;
     v_heiRownum int;
     v_lowRownum int;
 begin
   ----取记录总数
   v_sql := 'select count(*) from (' || p_SqlSelect || ')';
   execute immediate v_sql into v_count;
   p_OutRecordCount := v_count;
   ----执行分页查询
   v_heiRownum := p_PageNo * p_PageSize;
   v_lowRownum := v_heiRownum - p_PageSize + 1;
 
   v_sql := 'SELECT *
             FROM (
                   SELECT A.*, rownum rn
                   FROM  ('|| p_SqlSelect ||') A
                   WHERE rownum <= '|| to_char(v_heiRownum) || '
                  ) B
             WHERE rn >= ' || to_char(v_lowRownum) ;
             --注意对rownum别名的使用,第一次直接用rownum,第二次一定要用别名rn
 
   OPEN p_OutCursor FOR  v_sql;
 
 end sp_Page;
 
 /*****************************************************************
  *功能描述: 大数据量分页通用存储过程(重载1,推荐使用)
  *创建人:   Melodicsoul   
  *创建时间: 2007-05-28
  *****************************************************************/
 procedure sp_Page(p_PageSize int,          --每页记录数
                   p_PageNo int,            --当前页码,从 1 开始
                   p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_SqlCount varchar2,     --获取记录总数的查询语句
                   p_OutRecordCount out int,--返回总记录数
                   p_OutCursor out refCursorType)
 as
     v_sql varchar2(3000);
     v_count int;
     v_heiRownum int;
     v_lowRownum int;
 begin
   ----取记录总数
   execute immediate p_SqlCount into v_count;
   p_OutRecordCount := v_count;
   ----执行分页查询
   v_heiRownum := p_PageNo * p_PageSize;
   v_lowRownum := v_heiRownum - p_PageSize + 1;
 
   v_sql := 'SELECT *
              FROM (
                   SELECT A.*, rownum rn
                   FROM  ('|| p_SqlSelect ||') A
                   WHERE rownum <= '|| to_char(v_heiRownum) || '
                  ) B
             WHERE rn >= ' || to_char(v_lowRownum) ;
             --注意对rownum别名的使用,第一次直接用rownum,第二次一定要用别名rn
 
   OPEN p_OutCursor FOR  v_sql;
 
 end sp_Page;
 
 /*****************************************************************
  *功能描述: 大数据量分页通用存储过程(重载2)
  *创建人:   Melodicsoul   
  *创建时间: 2007-05-28
  *****************************************************************/
 procedure sp_Page(p_PageSize int,        --每页记录数
                   p_PageNo int,          --当前页码,从 1 开始
                   p_SqlSelect varchar2,  --查询语句,含排序部分
                   p_OutCursor out refCursorType)
 as
     v_sql varchar2(3000);
     --v_count int;
     v_heiRownum int;
     v_lowRownum int;
 begin
 /*
   ----取记录总数
   v_sql := 'select count(*) from (' || p_SqlSelect || ')';
   execute immediate v_sql into v_count;
   p_OutRecordCount := v_count;
 */
   ----执行分页查询
   v_heiRownum := p_PageNo * p_PageSize;
   v_lowRownum := v_heiRownum - p_PageSize + 1;
 
   v_sql := 'SELECT *
             FROM (
                   SELECT A.*, rownum rn
                   FROM  ('|| p_SqlSelect ||') A
                   WHERE rownum <= '|| to_char(v_heiRownum) || '
                  ) B
             WHERE rn >= ' || to_char(v_lowRownum) ;
             --注意对rownum别名的使用,第一次直接用rownum,第二次一定要用别名rn
 
   OPEN p_OutCursor FOR  v_sql;
 end sp_Page;
 /*****************************************************************
  *功能描述: 大数据量分页通用存储过程(重载3)
  *创建人:   Melodicsoul   
  *创建时间: 2007-05-28
  *****************************************************************/
 procedure sp_Page(p_SqlSelect varchar2,    --查询语句,含排序部分
                   p_OutRecordCount out int)--返回总记录数           
 as
     v_sql varchar2(3000);
     v_count int;
 begin
   ----取记录总数
   v_sql := 'select count(*) from (' || p_SqlSelect || ')';
   execute immediate v_sql into v_count;
   p_OutRecordCount := v_count;
 end sp_Page;
 end p_page;
/

分享到:
评论

相关推荐

    SSH+ORACLE通用分页

    总的来说,"SSH+Oracle通用分页"是Java Web开发中常见的需求,它涉及到SSH框架的集成使用和Oracle数据库的高效查询策略。理解并熟练掌握这些知识,对于开发高性能、用户体验良好的Web应用至关重要。在实际项目中,还...

    Oracle通用分页存储过程

    "Oracle通用分页存储过程"就是为了解决这个问题而设计的。分页存储过程通常包含一系列SQL语句和逻辑,用于从数据库中按指定条件获取特定页码的数据。 在Oracle数据库中,实现分页查询通常涉及到`ROWNUM`伪列或者`...

    oracle存储过程通用分页

    这篇博客“Oracle存储过程通用分页”将深入探讨如何利用Oracle存储过程来实现高效、灵活的分页功能。 首先,理解分页的基本概念至关重要。分页是将大型数据集分成若干小块,每次只加载一部分数据到内存中,这样可以...

    完美整合(通用分页)SSH+Oracle (需要自己加入jar包,只是源码)

    分页实现**:在SSH+Oracle的环境下,实现通用分页通常有以下几种方法: - 使用Hibernate的Criteria API配合 ScrollableResults 实现分页。 - 利用HQL(Hibernate Query Language)进行分页查询。 - 自定义SQL...

    oracle和mssql分页存储过程-均通用

    要实现Oracle和MSSQL的通用分页存储过程,可以使用动态SQL。首先,根据数据库类型选择合适的分页语句,然后将分页参数(如页号、每页记录数)传入存储过程。这需要对两种数据库的语法有一定了解,并且可能需要处理...

    oracle查询分页条件通用存储过程

    oracle数据库的查询分页加条件和排序的通用型存储过程,通过将表名以参数的形式传入到存储过程中做到多表通用,也可以是多表关联的sql语句 将其看作一个表也能调用该存储过程,分页只需要传与页数,和每页显示的行数...

    Oracle通用数据库存储过程代码--高效分页存储过程

    ### Oracle通用数据库存储过程代码——高效分页存储过程解析 #### 标题解析 标题“Oracle通用数据库存储过程代码——高效分页存储过程”表明这是一个适用于Oracle数据库的存储过程,主要用于实现高效的分页查询功能...

    Mybatis通用分页插件

    Mybatis通用分页插件是Java开发中广泛使用的ORM(对象关系映射)框架扩展,主要针对Mybatis进行优化,提供了高效便捷的分页功能。这个插件的目的是简化在数据库查询时的分页操作,使得开发者能够更专注于业务逻辑,...

    java通用分页代码实例.rar

    这个"java通用分页代码实例"提供了一种适用于任意数据库的解决方案,具有高可移植性和易用性。 分页的核心在于对数据库查询结果进行分割,只返回当前页面所需的数据,同时提供翻页链接或按钮,允许用户浏览更多的...

    java web Pager通用分页组件(源码)

    超级强悍的java web通用分页组件,只要简单的一条sql语句就可以轻松的实现分页,目前对oracle,SQL Server2005,SQL server200,mysql都做了实现,程序通过接口来封装,你可以实现对其他数据库的分页。里面有调用例子...

    TERADATA、ORACLE数据库分页

    3. `BasicService.java`: 基础服务类,可能包含了数据库操作的通用方法,如CRUD操作,但不包括具体的分页实现。 4. `Action.java.txt`: 这看起来像是一个ACTION类,通常在Java Web应用中用于处理用户请求,它可能...

    java中mysql和oracle数据库通用分页功能实现完整Demo

    开发环境:SpringBoot+SSM,同样适合SpringBoot,具备一定Maven项目基础初学者,详细说明地址http://blog.csdn.net/fjekin/article/details/75541573

    C#版Oracle数据库通用操作类

    ### C# 版 Oracle 数据库通用操作类解析 在现代软件开发中,数据库操作是必不可少的一部分,而 C# 结合 Oracle 数据库的应用尤为广泛。本文将深入探讨一个用于简化 Oracle 数据库操作的 C# 类——`ConnForOracle`。...

    Oracle数据库中很实用的分页查询代码

    分页查询是Oracle数据库比较重要的一个知识点!希望这个对你有参照作用。

    导出EXCEL,分页及连接oracle的jar包

    本主题聚焦于"导出EXCEL,分页及连接Oracle的jar包",这是一组常用且至关重要的工具,对于提升开发效率有着显著的作用。 首先,我们来看"导出EXCEL的jar包poi"。Apache POI是Java社区中广泛使用的库,用于读取和...

    oracle分页查询

    在Oracle数据库中,分页查询是一项非常常见的操作,特别是在处理大量数据时,为了提高用户体验,通常需要只显示一部分数据,而不是一次性加载所有记录。本文将详细介绍Oracle中的分页查询原理及其实现方法。 首先,...

    通用ORACLE存储过程实现分页和查询

    这个通用的存储过程简化了在Oracle中的分页操作,但需要注意的是,如果查询涉及到多表连接,性能可能会受到影响,因为ROWNUM是在查询整个结果集之后应用的。为了优化,可以考虑使用Oracle的ROW_NUMBER()函数配合窗口...

    struts2+spring+ibatis+oracle+分页搜索+上传附件实例

    使用Oracle的分页功能,可以高效地处理大量数据的查询,同时,其强大的数据类型支持附件的存储。 5. **分页搜索**:在Web应用中,分页搜索是提升用户体验的重要手段。通过在后台实现SQL的分页查询,Struts2和Spring...

    Oracle数据库通用的分页存储过程

    Oracle数据库中实现分页查询主要有两种方法:ROWNUM和ROW_NUMBER()函数,这里我们主要讨论通过存储过程实现的通用分页方法。 一、ROWNUM方法 ROWNUM是Oracle数据库中的一个伪列,它会为每一行分配一个唯一的整数,...

    Java 通用分页

    本文将详细探讨Java中的通用分页实现方法。 首先,我们要理解分页的基本概念。分页主要包括两个关键参数:当前页码(Page Number)和每页显示条数(Page Size)。通过这两个参数,我们可以计算出当前页面应该显示的...

Global site tag (gtag.js) - Google Analytics