代码语言
.
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
】
AspNetPager与MSSQL海量分页存储过程结合
作者:
Dezai.CN
/ 发布于
2013/1/29
/
611
存储过程: CREATE PROCEDURE UP_GetRecordByPageOrder @tblName varchar(255), -- 表名 @fldName varchar(255), -- 显示字段名 @OrderfldName varchar(255), -- 排序字段名 @StatfldName varchar(255), -- 统计字段名 @PageSize int = 10, -- 页尺寸 @PageIndex int = 1, -- 页码 @IsReCount bit = 0, -- 返回记录总数, 非0 值则返回 @OrderType bit = 0, -- 设置排序类型, 非0 值则降序 @strWhere varchar(1000) = '' -- 查询条件(注意: 不要加where) AS declare @strSQL varchar(6000) -- 主语句 declare @strTmp varchar(100) -- 临时变量 declare @strOrder varchar(400) -- 排序类型 if @OrderType > 0 begin set @strTmp = '<(select min' set @strOrder = ' order by [' + @OrderfldName +'] desc' end else begin set @strTmp = '>(select max' set @strOrder = ' order by [' + @OrderfldName +'] asc' end set @strSQL = 'select top ' + str(@PageSize) + ' ' + @fldName + ' from [' + @tblName + '] where [' + @OrderfldName + ']' + @strTmp + '([' + @OrderfldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' [' + @OrderfldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)' + @strOrder if @strWhere != '' set @strSQL = 'select top ' + str(@PageSize) + ' ' + @fldName + ' from [' + @tblName + '] where [' + @OrderfldName + ']' + @strTmp + '([' + @OrderfldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' [' + @OrderfldName + '] from [' + @tblName + '] where ' + @strWhere + ' ' + @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder if @PageIndex = 1 begin set @strTmp = '' if @strWhere != '' set @strTmp = ' where ' + @strWhere set @strSQL = 'select top ' + str(@PageSize) + ' ' + @fldName + ' from [' + @tblName + ']' + @strTmp + ' ' + @strOrder end if @IsReCount > 0 set @strSQL = @strSQL+' select count(1) as Total from [' + @tblName + ']' if @strWhere!='' set @strSQL = @strSQL+' where ' + @strWhere exec (@strSQL) GO cs部分: #region 获取分页列表 /// <summary> /// Pg_Paging /// </summary> /// <param name="Tables"></param> /// <param name="PK"></param> /// <param name="Sort"></param> /// <param name="PageNumber"></param> /// <param name="PageSize"></param> /// <param name="Fields"></param> /// <param name="Filter"></param> /// <param name="Group"></param> /// <returns></returns> public static DataSet Pg_Paging(string TableName, string PK, string Fields, int PageSize, int PageIndex, bool OrderType, string Sort, string Filter, bool isCount) { //存储过程名 string storedProcName = "Pagination"; //设置参数 SqlParameter[] para = new SqlParameter[] { new SqlParameter("@tblName",TableName), new SqlParameter("@PKName",PK), new SqlParameter("@strGotFields",Fields), new SqlParameter("@PageSize",PageSize), new SqlParameter("@PageIndex",PageIndex), new SqlParameter("@OrderType",OrderType), new SqlParameter("@strSort",Sort), new SqlParameter("@strWhere",Filter), new SqlParameter("@isCount",isCount) }; return DBUtility.DbHelperSQL.RunProcedure(storedProcName, para, "singleselectinfo"); } #endregion protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { SubjectBind(); } } //绑定单选题列表 protected void SingleSelectBind() { string table = " SingleSelect "; string pk = " SingleSelectID "; string sort = "SingleSelectID"; bool ordertype = false; int pageindex = 0; int pagesize = 1; string fields = " SingleSelectID,Title "; string filter = "IsDeleted = 0"; if (AspNetPager1.CurrentPageIndex < 1) { pageindex = 1; } else { pageindex = AspNetPager1.CurrentPageIndex; } //动态设置用户自定义文本内容 AspNetPager1.RecordCount = Pg_PageCount(table, pk, filter, sort); AspNetPager1.PageSize = pagesize; this.GridView1.DataSource = Pg_Paging(table, pk, fields, pagesize, pageindex, ordertype, sort, filter, false).DefaultView; this.GridView1.DataBind(); } protected void AspNetPager1_PageChanged(object src, EventArgs e) { SingleSelectBind(); }
试试其它关键字
分页
同语言下
.
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