`
zhuqinglin
  • 浏览: 28014 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

oracle分页存储过程

 
阅读更多

在实际的应用中我们可以根据自己的想法用Oracle存储过程做一个页的相关的存储过程,下面的文章主要是和大家分享Oracle存储过程的经验心得,希望你能通此文章对其的实际操作有个更好的了解。

之所以用存储过程,是因为以后需要修改的话不需要修改程序代码,只需要修改Oracle存储过程的代码。但这个例子是在存储过程里动态生成的SQL语句,不知道会不会因此失去存储过程一次编译和快速的特点。代码如下:

1、首先建立一个包,用户创建一个游标类型

1 create or replace package pkg_query as  

2 type cur_query is ref cursor;  

3 end pkg_query;  

2、创建Oracle存储过程

4 create OR REPLACE PROCEDURE prc_query  

5 (p_tableName in varchar2,   

表名

6 p_strwhere in varchar2,  

查询条件 --*

7 p_orderColumn in varchar2,  

排序的列 --*

8 p_orderStyle in varchar2,  

排序方式 --*

9 p_curPage in out Number, 

当前页

10 p_pageSize in out Number,  

每页显示记录条数

11 p_totalRecords out Number,  

总记录数

12 p_totalPages out Number,  

总页数

13 v_cur out pkg_query.cur_query)  

返回的结果集

14 IS  

15 v_sql VARchar2(1000) := ’’;   

sql语句

16 v_startRecord Number(4);  

开始显示的记录条数

17 v_endRecord Number(4); 

结束显示的记录条数

18 BEGIN 

记录中总记录条数

19 v_sql := ’select TO_NUMBER(count(*)) FROM ’ || p_tableName || ’ where 11=1’;  

20 IF p_strwhere IS NOT NULL or p_strwhere <> ’’ THEN  

21 v_sql := v_sql || p_strwhere;  

22 END IF;  

23 execute IMMEDIATE v_sql INTO p_totalRecords;  

验证页面记录大小

24 IF p_pageSize < 0 THEN  

25 p_pageSize := 0;  

26 END IF;  

根据页大小计算总页数

27 IF MOD(p_totalRecords,p_pageSize) = 0 THEN  

28 p_totalPages := p_totalRecords / p_pageSize;  

29 ELSE  

30 p_totalPages := p_totalRecords / p_pageSize + 1;  

31 END IF;   

 

 

 

1.创建测试表

Sql代码

create table Account

    cardId char(20primary key,  --帐号

    name char(20not null,         --姓名

        money numeric(20,2)         --存款

); 

 2.录入测试数据

Sql代码

insert into Account values('0001','张三',1000); 

insert into Account values('0002','李四',2000); 

insert into Account values('0003','王五',3000); 

insert into Account values('0004','钱六',4000); 

 3,编写一个视图以简化存储过程的编写与调用写法

Sql代码

create or replace view v_page  

as 

select rownum rn,t.* from Account t; 

 4,编写存储过程(省略了查询条件)

Sql代码

create or replace procedure P_Pagination( 

       page  int,--第几页

       perPageCount int ,--每页几条记录

       totalPage out int,--总页数

       pageResultSet out SYS_REFCURSOR --当前页查询出来的结果集  

as 

   totalCount int;--总记录数

   pageSql varchar(2000); --查询某页结果的SQL语句

begin 

  select count(1into totalCount from Account;  --查询总记录数

  totalPage := ceil( totalCount / perPageCount);   --算出总页数

  pageSql := 'select * from v_page u  

    where rn between '||(page-1)||'*'||perPageCount||'+1 and '||(page*perPageCount); 

   open pageResultSet for pageSql; 

end P_Pagination; 

 5,在PL/SQL中调用该存储过程

Sql代码

declare  

   totalaPage int;  --总页数

   pageResult  SYS_REFCURSOR--存放结果的变量

   account v_page%rowtype

 begin 

    P_Pagination(1,2,totalaPage,pageResult); 

    dbms_output.put_line('总共'||totalaPage||'页'); 

    fetch pageResult into account

   while pageResult%found loop 

      dbms_output.put_line(account.cardid||','||account.name||','||account.money); 

      fetch pageResult into account

    end loop

   close pageResult; 

end

 6,使用JDBC调用的代码片段

Java代码

public static void main(String[] args) throws SQLException { 

    Connection conn = ConnectionManage.getConnection(); 

    CallableStatement cs = conn.prepareCall("call P_Pagination(?,?,?,?)"); 

    cs.setInt(11); 

    cs.setInt(23); 

    cs.registerOutParameter(3, Types.INTEGER); 

    cs.registerOutParameter(4, oracle.jdbc.OracleTypes.CURSOR); 

    cs.execute(); 

    int totalPage = cs.getInt(3); 

    System.out.println("共有" + totalPage + "页"); 

    ResultSet rs = (ResultSet) cs.getObject(4); 

    while (rs.next()) { 

        System.out.println(rs.getString("cardid")+","+rs.getString("name") +"," + rs.getString("money")); 

    } 

}   

<!--EndFragment-->
分享到:
评论

相关推荐

    Oracle分页存储过程

    ### Oracle分页存储过程解析与应用 在数据库管理和应用程序开发中,处理大量数据时,分页查询是一项常用且重要的技术。Oracle数据库提供了多种方法来实现数据分页,其中使用存储过程进行分页是一种高效且灵活的方式...

    Oracle 分页存储过程 终极版

    "Oracle分页存储过程 终极版"旨在提供一个高效、灵活的解决方案,以应对各种分页查询的需求。这个存储过程优化了性能,并支持各种条件筛选和排序,使得在海量数据中进行分页操作变得更为便捷。 首先,理解分页的...

    ORACLE分页存储过程

    在分页存储过程中,主要理解了变量的动态赋值和输入输出参数的使用就非常简单了 下面为调用方法: var c_Preccount number; var c_Ppagecount number; var c_cur refcursor; exec proc_SpPag(1,'SELECT * FROM T_...

    Oracle 分页存储过程

    本文将深入解析一个Oracle分页存储过程的设计思想与具体实现方法。该存储过程通过输入参数控制每页显示的记录数,并返回指定页面的数据,同时提供了总记录数和总页数等信息。 #### 知识点二:存储过程定义与结构...

    Oracle 分页的存储过程

    总结来说,Oracle分页存储过程是通过动态构造SQL语句,结合输入的分页参数,计算出总页数,并返回指定页的数据。这种方式在处理大量数据时提高了效率,同时也提供了灵活的查询控制。通过包装这些逻辑在存储过程中,...

    oracle 分页 存储过程

    oracle 分页 存储过程,超级牛的分页存储过程,执行后可以直接实用,分页速度刚刚的

    带排序的oracle分页存储过程

    ### 带排序的Oracle分页存储过程 在开发Web应用程序的过程中,分页是一个非常常见的需求。为了提高系统的性能及可维护性,采用存储过程来实现分页逻辑是一种较为推荐的做法。下面将详细介绍如何利用Oracle数据库中...

    Oracle 分页存储过程 SQL

    Oracle 分页存储过程 SQL Oracle 分页存储过程 SQL

    java调用oracle分页存储过程

    Java调用Oracle分页存储过程是一项常见的数据库操作,尤其在处理大数据量时,为了提高查询效率和用户体验,分页查询显得尤为重要。Oracle数据库提供了一种高效的方法,即通过创建存储过程来实现分页功能,而Java作为...

    oracle分页存储过程千万级

    本文将基于给定的“oracle分页存储过程千万级”文件信息,深入解析其核心概念、设计思路及实现细节。 ### 核心概念解析 #### 1. 存储过程(Stored Procedure) 存储过程是一种预编译的SQL代码块,存储在数据库...

    oracle 分页存储过程

    本篇文章将深入探讨Oracle中的分页存储过程,以及如何利用源码和工具来实现这一功能。 在Oracle数据库中,进行分页查询通常涉及到ROWNUM伪列和子查询。ROWNUM是在数据检索时由Oracle自动生成的一个整数值,表示行的...

    asp.net使用oracle分页存储过程查询数据

    功能说明 写好oracle的连接字符串和查询语句,调用程序中的方法可以很方便的实现分页功能。该方法中,将参数连接字符串,查询的sql语句,... 效率不是很高,如有高人写出很厉害的分页存储过程,希望您与大家分享。

    (最好最优Oracle分页存储过程)UP_Sys_CommQuery_GetPageList

    ### Oracle 分页存储过程 UP_Sys_CommQuery_GetPageList 的详细解析 #### 一、概述 在Oracle数据库中实现高效的数据分页是一项重要的任务。本文将深入解析一个名为`UP_Sys_CommQuery_GetPageList`的存储过程,该...

Global site tag (gtag.js) - Google Analytics