打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
一个简单的oracle分页存储过程的实现和调用
oracle数据库中数据存储是非常常用的一个操作,下文中将为大家讲解一个简单的oracle分页存储过程的实现和调用,希望对大家有用。
AD:
在看了众多的分页存储过程以后发现都是针对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;
**************************************************************************************
上文中的内容有很多都是代码,对于刚刚入门的初学者可能不是很容易理解,希望大家能够认真的去学习上文中涉及到的内容,相信这些在大家日后的工作中会是很有用的。
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
oracle千万级数据分页存储过程优化
oracle高效分页存储过程代码
c# oracle 分页
Oracle存储过程实现多线程对表数据的抽取
Oracle PL/SQL随堂笔记总结
oracle存储过程分页处理
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服