王朝网络
分享
 
 
 

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

王朝asp·作者佚名  2006-01-09
宽屏版  字体: |||超大  

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

Prcount out 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,

Prcount out 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;

--**************************************************************************************

end DotNot;

------------------------------------------------------------------------------------------------------------------------------------------------------------------------

以下是在.net中调用oracle分页存储过程的步骤。(vb.net)

在.net调用返回记录集的存储过程,需要用到datareader,但是datareader不支持在datagrid中的分页,因此需要利用datagrid

自定义分页功能。

Protected WithEvents DataGrid1 As System.Web.UI.WebControls.DataGrid

Dim conn As New OracleClient.OracleConnection()

Dim cmd As New OracleClient.OracleCommand()

Dim dr As OracleClient.OracleDataReader

Private Sub gridbind(ByVal pindex As Integer, ByVal psql As String, Optional ByVal psize As Integer = 10)

conn.ConnectionString = "Password=gzdlgis;User ID=gzdlgis;Data Source=gzgis"

cmd.Connection = conn

cmd.CommandType = CommandType.StoredProcedure

conn.Open()

'------------------------------------------------------------------------------------

cmd.CommandText = "DotNot.DotNetPageRecordsCount"

'------------------------------------------------------------------------------------

cmd.Parameters.Add("psqlcount", OracleType.VarChar).Value = psql

cmd.Parameters.Add("prcount", OracleType.Number).Direction = ParameterDirection.Output

cmd.ExecuteNonQuery()

Me.DataGrid1.AllowPaging = True

Me.DataGrid1.AllowCustomPaging = True

Me.DataGrid1.PageSize = psize

Me.DataGrid1.VirtualItemCount = cmd.Parameters("prcount").Value

cmd.Parameters.Clear()

'------------------------------------------------------------------------------------

cmd.CommandText = "DotNot.DotNetPagination"

'------------------------------------------------------------------------------------

cmd.Parameters.Add("pindex", Data.OracleClient.OracleType.Number).Value = pindex

cmd.Parameters.Add("psql", Data.OracleClient.OracleType.VarChar).Value = psql '"select rownum rn,t.* from cd_ssxl t"

cmd.Parameters.Add("psize", Data.OracleClient.OracleType.Number).Value = psize

cmd.Parameters.Add("v_cur", Data.OracleClient.OracleType.Cursor).Direction = ParameterDirection.Output

cmd.Parameters.Add("pcount", Data.OracleClient.OracleType.Number).Direction = ParameterDirection.Output

dr = cmd.ExecuteReader()

Me.DataGrid1.DataSource = dr

Me.DataGrid1.DataBind()

dr.Close()

conn.Close()

Response.Write("总计页数 " & cmd.Parameters("pcount").Value)

End Sub

----------------------------------------------------------------------------------------------------------------------------------------------------------------

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

If Not Page.IsPostBack Then

Dim psql As String = "select rownum rn,t.* from cd_ssxl t"

gridbind(0, psql, 20)

End If

End Sub

----------------------------------------------------------------------------------------------------------------------------------------------------------------

Private Sub DataGrid1_PageIndexChanged(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridPageChangedEventArgs) Handles DataGrid1.PageIndexChanged

Dim psql As String = "select rownum rn,t.* from cd_ssxl t"

Me.DataGrid1.CurrentPageIndex = e.NewPageIndex

gridbind(e.NewPageIndex, psql, 20)

End Sub

-----------------------------------------------------------------------------------------------------------------------------------------------------------------

各位有什么高见不妨指点一二!谢谢

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有