成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一個簡單的oracle分頁存儲過程的實現和調用

數據庫 Oracle
oracle數據庫中數據存儲是非常常用的一個操作,下文中將為大家講解一個簡單的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;

 

 

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

上文中的內容有很多都是代碼,對于剛剛入門的初學者可能不是很容易理解,希望大家能夠認真的去學習上文中涉及到的內容,相信這些在大家日后的工作中會是很有用的。

 

責任編輯:迎迎 來源: 電腦初學網
相關推薦

2010-04-16 11:31:29

Oracle分頁存儲過

2010-05-06 14:01:12

Oracle分頁存儲過

2010-10-29 16:12:51

Oracle存儲過程

2010-10-26 14:50:11

oracle存儲過程

2010-04-15 17:45:26

Oracle存儲過程

2010-05-05 17:19:32

Oracle存儲過程

2010-11-29 09:12:46

sybase分頁存儲過

2010-04-30 08:47:22

Oracle分頁存儲

2010-05-05 14:55:15

Oracle存儲過程

2011-03-28 09:56:03

存儲增刪操作

2010-04-12 09:26:52

Oracle查詢分頁

2011-04-13 09:45:15

Oracle存儲

2011-07-29 13:21:31

CTE遞歸存儲過程真分頁

2010-11-10 15:16:14

Sql Server分

2010-04-29 17:31:56

Oracle存儲過程

2017-09-04 11:48:56

MybatisOracle存儲過程

2010-04-16 11:11:46

Oracle存儲過程

2010-10-29 16:17:55

Oracle存儲過程

2010-04-19 17:21:36

Oracle寫文件

2009-09-17 11:32:52

LINQ調用存儲過程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一级黄色片免费观看 | 亚洲欧美中文日韩在线v日本 | 男女又爽又黄视频 | 国产成人亚洲精品自产在线 | 亚洲三区在线观看 | 91黄色片免费看 | 久久精品国产久精国产 | 天堂久久久久久久 | 免费久久精品视频 | 成人黄色av网址 | 日韩在线播放一区 | 亚洲精品电影在线观看 | 正在播放国产精品 | 午夜寂寞影院列表 | 日韩欧美在线观看 | 亚洲成av人片在线观看无码 | 人人叉 | 天天干在线播放 | 欧美夜夜 | 日韩av第一页 | 亚洲精品一区二区三区蜜桃久 | 精品亚洲一区二区三区四区五区 | 精品在线一区二区三区 | 亚洲一av| 久久精品网 | 91久久 | 一区二区在线不卡 | 日日操夜夜操天天操 | 国产精品国产三级国产aⅴ中文 | 国产成人精品a视频一区www | 久久精品国产免费看久久精品 | 国产电影一区二区 | 91精品在线播放 | 久久免费看 | 99热在这里只有精品 | 欧美乱大交xxxxx另类电影 | 国产精品视频一区二区三区 | 日韩欧美综合在线视频 | 91视频进入 | 二区中文 | 日韩国产中文字幕 |