• 我们都知道用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分页存储过程截下来就是调用。