我们都知道用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 返回分页数据的游标
- ) AS
 - v_sql VARCHAR2(1000);
 - v_Pbegin number;
 - v_Pend number;
 - begin
 - v_sql := 'select count(*) from (' || Psql || ')';
 - execute immediate v_sql into Prowcount;
 
计算记录总数
- Pcount := ceil(Prowcount / Psize);
 
计算分页总数,显示任意页内容
- v_Pend := Pindex * Psize + Psize;
 - v_Pbegin := v_Pend - Psize + 1;
 - v_sql := 'select * from (' || Psql || ') where rn between ' || v_Pbegin || ' and ' || v_Pend;
 - open v_cur for v_sql;
 - end Pagination;
 - end JT_P_page;
 
这个是在网上找的,还不错 主要是根据伪列 rownum作为where查询条件 进行帅选,,通过这次做这个Oracle分页算是对rownum有了初步的认识,实践出真理 , 有了Oracle分页存储过程截下来就是调用。
Copyright © 2009-2022 www.wtcwzsj.com 青羊区广皓图文设计工作室(个体工商户) 版权所有 蜀ICP备19037934号