一个简单的oracle分页存储过程的实现和调用 电脑资料_第1页
一个简单的oracle分页存储过程的实现和调用 电脑资料_第2页
一个简单的oracle分页存储过程的实现和调用 电脑资料_第3页
一个简单的oracle分页存储过程的实现和调用 电脑资料_第4页
一个简单的oracle分页存储过程的实现和调用 电脑资料_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一个简单的oracle分页存储过程的实现和调用 电脑资料 在看了众多的分页存储过程以后发现都是针对sqlserver的,而没有oracle的,因此想写一个关于oracle的存储过程,因为我用到的数据库是oracle. - oracle分页存储过程的思路于sqlserver的思路是一样的,但是我这里做了点改动,在因为oracle的语法和规则的不同所以,oracle分页 存储过程看上去有点不一样, 在oracle的存储过程中返回记录集,需要用到游标变量,oracle不能像sqlserver那样可以直接返回一个记录集。 由于设想在.中把复杂的sql语句生成,所以在存储过程中没有去考虑生成sql语句的问题。 - 以下是在oracle中实现的分页存储过程。 create or replace package DotNet is - Author : good_hy - Created : xx-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; - 以下是在.中调用oracle分页存储过程的步骤, 在.调用返回记录集的存储过程,需要用到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.DataGridPageChangedEventA

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论