代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Asp.Net
】
Oracle通用分页存储过程和AspNetPage结合
作者:
Dezai.CN
/ 发布于
2013/5/13
/
798
--包头部分 create or replace package JT_P_page is type type_cur is ref cursor; --定义游标变量用于返回记录集 procedure Pagination (Pindex in number, --要显示的页数索引,从0开始 Psql in varchar2, --产生分页数据的查询语句 Psize in number, --每页显示记录数 Pcount out number, --返回的分页数 Prowcount out number, --返回的记录数 v_cur out type_cur --返回分页数据的游标 ); end JT_P_page; --包体部分 create or replace package body JT_P_page is procedure Pagination(Pindex in number, --要显示的页数索引,从0开始 Psql in varchar2, --产生分页数据的查询语句 Psize in number, --每页显示记录数 Pcount out number, --返回的分页数 Prowcount out number, --返回的记录数 v_cur out type_cur --返回分页数据的游标 ) AS v_sql VARCHAR2(1000); v_Pbegin number; v_Pend number; begin v_sql := 'select count(*) from (' || Psql || ')'; execute immediate v_sql into Prowcount; --计算记录总数 Pcount := ceil(Prowcount / Psize); --计算分页总数 --显示任意页内容 v_Pend := Pindex * Psize + Psize; v_Pbegin := v_Pend - Psize + 1; v_sql := 'SELECT * FROM (SELECT a.*, ROWNUM rn FROM (' || Psql || ') a) WHERE rn >= ' || v_Pbegin || ' AND rn <= ' || v_Pend; DBMS_OUTPUT.put_line(v_sql); open v_cur for v_sql; end Pagination; end JT_P_page; protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { BindGridView(0, "DD_Demo", AspNetPager1.PageSize); } } /// <summary> /// 数据绑定 /// </summary> /// <param name="index">当前页码</param> /// <param name="sql">表名或者视图名</param> /// <param name="pageSize">每页显示记录数</param> private void BindGridView(int index, string sql, int pageSize) { int totalCount = 0; int pageCount = 0; DataTable dt = ReturnDataTable(index, sql, pageSize, out totalCount, out pageCount); GridView1.DataSource = dt; GridView1.DataBind(); AspNetPager1.RecordCount = totalCount; AspNetPager1.PageSize = pageSize; AspNetPager1.CustomInfoHTML = " 共<font color='#FF8000'><b>" + AspNetPager1.RecordCount.ToString() + "</b></font>条记录"; AspNetPager1.CustomInfoHTML += " 当前第<font color=\"red\"><b>" + AspNetPager1.CurrentPageIndex.ToString() + "</b></font>页"; AspNetPager1.CustomInfoHTML += "/共<font color=#FF8000'><b>" + AspNetPager1.PageCount.ToString() + "</b></font>页"; } /// <summary> /// 执行存储过程返回分页数据 /// </summary> /// <param name="index">当前页码</param> /// <param name="sql">表名或者视图名</param> /// <param name="pageSize">每页显示记录数</param> /// <param name="totalCount">返回记录总数</param> /// <param name="pageCount">返回页面总数</param> /// <returns></returns> public static DataTable ReturnDataTable(int index, string sql, int pageSize, out int totalCount,out int pageCount) { DataTable dt = new DataTable(); try { OracleParameter[] param = new OracleParameter[] { new OracleParameter("Pindex", OracleType.Number), new OracleParameter("Psql", OracleType.VarChar), new OracleParameter("Psize", OracleType.Number), new OracleParameter("Pcount", OracleType.Number), new OracleParameter("Prowcount", OracleType.Number), new OracleParameter("v_cur", OracleType.Cursor) }; param[0].Value = index; param[1].Value = sql; param[2].Value = pageSize; param[0].Direction = ParameterDirection.Input; param[1].Direction = ParameterDirection.Input; param[2].Direction = ParameterDirection.Input; param[3].Direction = ParameterDirection.Output; param[4].Direction = ParameterDirection.Output; param[5].Direction = ParameterDirection.Output; dt = Maticsoft.DBUtility.DbHelperOra.RunProcedure("JT_P_page.Pagination", param, "queryTable").Tables["queryTable"]; pageCount = int.Parse(param[3].Value.ToString()); totalCount = int.Parse(param[4].Value.ToString()); } catch (Exception ex) { throw new Exception(ex.Message); } return dt; } protected void AspNetPager1_PageChanged(object sender, EventArgs e) { BindGridView(AspNetPager1.CurrentPageIndex - 1, "DD_Demo", AspNetPager1.PageSize); }
试试其它关键字
分页存储过程
同语言下
.
gzip压缩
.
实现http多线程断点续传下载文件
.
实现多线程断点续传下载大文件
.
生成字符串的 CheckSum
.
根据 UserAgent 获取浏览器的类型和版本
.
根据 Agent 判断是否是智能手机
.
隐藏手机号中间四位为*方法
.
合并图片(二维码和其他图片合并)
.
ASP.NET CORE中判断是否移动端打开网页
.
ASP.NET(C#)实现页面计时(定时)自动跳转
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3