一个简单的oracle分页存储过程的实现和调用

在看了众多的分页存储过程以后发现都是针对sqlserver的,而没有oracle的,因此想写一个关于oracle的存储过程,因为我用到的数据库是oracle.oracle分页存储过程的思路于sqlserver的思路是一样的,但是我这里做了点改动,在因为oracle的语法和规则的不同所以,oracle分页存储过程看上去有点不一样。

站在用户的角度思考问题,与客户深入沟通,找到温岭网站设计与温岭网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、成都做网站、企业官网、英文网站、手机端网站、网站推广、域名注册雅安服务器托管、企业邮箱。业务覆盖温岭地区。

在oracle的存储过程中返回记录集,需要用到游标变量,oracle不能像sqlserver那样可以直接返回一个记录集。

由于设想在.net中把复杂的sql语句生成,所以在存储过程中没有去考虑生成sql语句的问题。

以下是在oracle中实现的分页存储过程。

create or replace package DotNet is

Author: good_hy

Created : 20041213 13:30:30

Purpose :

TYPE type_cur IS REF CURSOR;定义游标变量用于返回记录集

PROCEDURE DotNetPagination(

Pindex in number,分页索引

Psql in varchar2,产生dataset的sql语句

Psize in number,页面大小

Pcount out number,返回分页总数

v_cur out type_cur返回当前页数据记录

);

procedure DotNetPageRecordsCount(

Psqlcount in varchar2,产生dataset的sql语句

Prcountout number返回记录总数

);

end DotNot;

create or replace package body DotNet is

***************************************************************************************

PROCEDURE DotNetPagination(

Pindex in number,

Psql in varchar2,

Psize in number,

Pcount out number,

v_cur out type_cur

)

AS

v_sql VARCHAR2(1000);

v_count number;

v_Plow number;

v_Phei number;

Begin

取分页总数

v_sql := 'select count(*) from (' || Psql || ')';

execute immediate v_sql into v_count;

Pcount := ceil(v_count/Psize);

显示任意页内容

v_Phei := Pindex * Psize + Psize;

v_Plow := v_Phei Psize + 1;

Psql := 'select rownum rn,t.* from cd_ssxl t' ;要求必须包含rownum字段

v_sql := 'select * from (' || Psql || ') where rn between ' || v_Plow || ' and ' || v_Phei ;

open v_cur for v_sql;

End DotNetPagination;

**************************************************************************************

procedure DotNetPageRecordsCount(

Psqlcount in varchar2,

Prcountout number

)

as

v_sql varchar2(1000);

v_prcount number;

begin

v_sql := 'select count(*) from (' || Psqlcount || ')';

execute immediate v_sql into v_prcount;

Prcount := v_prcount;返回记录总数

end DotNetPageRecordsCount;

**************************************************************************************

上文中的内容有很多都是代码,对于刚刚入门的初学者可能不是很容易理解,希望大家能够认真的去学习上文中涉及到的内容,相信这些在大家日后的工作中会是很有用的。

分享文章:一个简单的oracle分页存储过程的实现和调用
链接URL:http://www.shufengxianlan.com/qtweb/news6/399706.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联