1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

我们都知道用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_sqlVARCHAR2(1000); 
v_Pbeginnumber; 
v_Pendnumber; 
begin 
v_sql:='selectcount(*)from('||Psql||')'; 
executeimmediatev_sqlintoProwcount;

计算记录总数

Pcount:=ceil(Prowcount/Psize);

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

v_Pend:=Pindex*Psize+Psize; 
v_Pbegin:=v_Pend-Psize+1; 
v_sql:='select*from('||Psql||')wherernbetween'||v_Pbegin||'and'||v_Pend; 
openv_curforv_sql; 
endPagination; 
endJT_P_page;

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

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11504.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。