一个简单的oracle分页存储过程的实现和调用
创始人
2024-07-29 07:51:29
0

在看了众多的分页存储过程以后发现都是针对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;

 

 

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

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

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...