分享
 
 
 

自定义分页控件用于DataGrid(使用SQL储存过程)

王朝mssql·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

分页储存过程:

网上找的一个改了一下!

/*

函数名称: GetRecordFromPage

函数功能: 获取指定页的数据

参数说明:

@tblName 包含数据的表名

@PKName 关键字段名

@strGotFields 要获取的字段

@PageSize 每页记录数

@PageIndex 要获取的页码

@OrderType 排序类型, 0 - 升序, 1 - 降序

@strWhere 查询条件 (注意: 不要加 where)

@isCount 是否取得记录条数 , 0 - 不取 , 1 - 获取

@strSort 排序字段

*/

CREATE PROCEDURE GetRecordFromPage

@tblName varchar(255), -- 表名

@PKName varchar(255), -- 字段名

@strGotFields varchar(1000) = '*' , --查询字段名

@PageSize int = 10, -- 页尺寸

@PageIndex int = 1, -- 页码

@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序

@strWhere varchar(2000) = '' , -- 查询条件 (注意: 不要加 where)

@isCount bit = 1, --取得记录条数

@strSort varchar(255) = '' --排序字段

AS

declare @strSQL varchar(6000) -- 主语句

declare @strTmp varchar(1000) -- 临时变量

declare @strOrder varchar(500) -- 排序类型

declare @strCount varchar(1000)

declare @fldName varchar(255)

declare @sortName varchar(255)

declare @countSQL varchar(1000)

set @fldName = @PKName

if @strSort != ''

begin

set @sortName = @strSort

end

else

begin

set @sortName = @PKName

end

if @isCount = 1

begin

if @strWhere != ''

begin

set @countSQL = 'select count(' + @fldName + ') from ' + @tblName + ' where ' + @strWhere

end

else

begin

set @countSQL = 'select count(' + @fldName + ') from ' + @tblName

end

exec (@countSQL)

return

end

else

begin

if @OrderType != 0

begin

set @strTmp = '<(select min'

set @strOrder = ' order by ' + @sortName + ' desc'

end

else

begin

set @strTmp = '>(select max'

set @strOrder = ' order by ' + @sortName +' asc'

end

set @strSQL = 'select top ' + str(@PageSize) + @strGotFields + ' from '

+ @tblName + ' where ' + @fldName + '' + @strTmp + '('

+ @fldName + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ' '

+ @fldName + ' from ' + @tblName + '' + @strOrder + ') as tblTmp)'

+ @strOrder

if @strWhere != ''

set @strSQL = 'select top ' + str(@PageSize) + @strGotFields + ' from '

+ @tblName + ' where ' + @fldName + '' + @strTmp + '('

+ @fldName + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ' '

+ @fldName + ' 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) + @strGotFields + ' from '

+ @tblName + '' + @strTmp + ' ' + @strOrder

end

exec (@strSQL)

end

GO

分页控件

在网上也查看了一些分页控件代码,大多都是做成通用的,对我所用的项目不太适合

自已写了一个功能不多,只分页与排序,刚合适合当前项目!

using System;

using System.Text;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Collections.Specialized;

using System.ComponentModel;

using System.Data;

using System.Data.SqlClient;

namespace WebAppInc

{

/// <summary>

/// /*

///函数名称: GetRecordFromPage

///函数功能: 获取指定页的数据

///参数说明:

///@tblName 包含数据的表名

///@PKName 关键字段名

///@strGotFields 要获取的字段

///@PageSize 每页记录数

///@PageIndex 要获取的页码

///@OrderType 排序类型, 0 - 升序, 1 - 降序

///@strWhere 查询条件 (注意: 不要加 where)

///@isCount 是否取得记录条数 , 0 - 不取 , 1 - 获取

/// @strSort 排序字段

///*/

/// </summary>

[DefaultProperty("EnableCustomerStyle"),

ToolboxData("<{0}:CusPageCtrl runat=server></{0}:CusPageCtrl>")]

public class CusPageCtrl:System.Web.UI.Control,IPostBackDataHandler, IPostBackEventHandler

{

private int _PageSize;

private int _PageCount;

private string _TableName;

private string _SelectFields;

private string _SortField;

private int _CurPageIndex;

private string _btDGrid;

private DataView _datasource;

private OrderType itype;

private string _SelectWhere;

private string _DataKeyField;

private string _selectClass;

private bool isCount = true;

private string _itemClass;

public enum OrderType

{

Asc,Desc

}

public string PageCssClass

{

get{ return _itemClass; }

set{ _itemClass = value;}

}

public string CurPageCssClass

{

get{ return _selectClass; }

set{ _selectClass = value;}

}

/// <summary>

/// 排序方式

/// </summary>

[Bindable(true),Category("Appearance"),DefaultValue("")]

public OrderType Order

{

get{ return itype; }

set{ itype = value;}

}

/// <summary>

/// 分页数

/// </summary>

public int PageCount

{

get{ return _PageCount; }

}

/// <summary>

/// 关键字段

/// </summary>

[Bindable(true),Category("Appearance"),DefaultValue("")]

public string SelectKeyField

{

get{ return _DataKeyField; }

set{ _DataKeyFie

[1] [2] [3] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
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- 王朝網路 版權所有