调用Oracle 分页存储过程更为快捷的方案

数据库 Oracle
以下的文章主要是介绍一种更为快捷的方法来实现Oracle 分页存储过程,以下就是具体方案的描述,希望在你今后的学习中会有所帮助。

我们都知道用ASP.NET来调用Oracle分页存储过程要结合ASPnetpager分页控件,来实现分页的自动功能,在2010-01-31 21:01之前我们用的都是GridView自带的分页功能,那速度啊慢的真实不行 ,决定自定义分页 Oracle库里有5W多条数据,AspnetPager做的还是不错,拿过来用。

Oracle 分页存储过程:

create or replace package JT_P_page is

type type_cur is ref cursor; 定义游标变量用于返回记录集

 

procedure Pagination (Pindex in number, 要显示的页数索引,从0开始

 

Psql in varchar2, 产生分页数据的查询语句

 

Psize in number, 每页显示记录数

 

Pcount out number, 返回的分页数

 

Prowcount out number, 返回的记录数

 

v_cur out type_cur 返回分页数据的游标

 

);

 

end JT_P_page;

 

定义包主体

 

create or replace package body JT_P_page is

 

procedure Pagination(Pindex in number, 要显示的页数索引,从0开始

 

Psql in varchar2, 产生分页数据的查询语句

 

Psize in number, 每页显示记录数

 

Pcount out number, 返回的分页数

 

Prowcount out number, 返回的记录数

 

v_cur out type_cur 返回分页数据的游标

 

  1. ) AS  
  2. v_sql VARCHAR2(1000);  
  3. v_Pbegin number;  
  4. v_Pend number;  
  5. begin  
  6. v_sql :'select count(*) from (' || Psql || ')';  
  7. execute immediate v_sql into Prowcount;  

计算记录总数

  1. Pcount :ceil(Prowcount / Psize);  

计算分页总数,显示任意页内容

 

  1. v_Pend :Pindex * Psize + Psize;  
  2. v_Pbegin :v_Pend - Psize + 1;   
  3. v_sql :'select * from (' || Psql || ') where rn between ' || v_Pbegin || ' and ' || v_Pend;   
  4. open v_cur for v_sql;  
  5. end Pagination;   
  6. end JT_P_page; 

这个是在网上找的,还不错 主要是根据伪列 rownum作为where查询条件 进行帅选,,通过这次做这个Oracle分页算是对rownum有了初步的认识,实践出真理 , 有了Oracle分页存储过程截下来就是调用。

 

【编辑推荐】

  1. Oracle存储过程的编写经验总结
  2. Oracle11g认证考试的3个主要途径
  3. Oracle数据库中3种常用的关闭方式
  4. Oracle数据库中经常使用的启动方式介绍
  5. 用触发器实现Oracle操作日志

 

责任编辑:佚名 来源: 互联网
相关推荐

2010-05-06 14:01:12

Oracle分页存储过

2010-04-30 08:47:22

Oracle分页存储

2010-10-26 14:50:11

oracle存储过程

2010-04-30 11:29:19

Oracle Data

2011-05-17 15:13:59

oracle分页存储

2010-11-10 15:16:14

Sql Server分

2010-04-12 09:26:52

Oracle查询分页

2011-06-17 17:37:16

JavaSQL Server

2010-04-16 11:11:46

Oracle存储过程

2010-10-29 16:12:51

Oracle存储过程

2017-09-04 11:48:56

MybatisOracle存储过程

2011-08-16 16:59:58

PLSQL分页存储过程Java

2010-05-05 17:19:32

Oracle存储过程

2009-07-22 15:58:34

JDBC调用Oracl

2010-04-12 10:16:55

Oracle存储过程

2010-05-05 14:55:15

Oracle存储过程

2010-05-05 09:18:53

Oracle创建存储过

2010-04-16 11:03:02

Oracle存储过程

2010-11-29 09:12:46

sybase分页存储过

2011-03-24 13:38:47

SQL Server 存储分页
点赞
收藏

51CTO技术栈公众号