100分 datagird 分页问题
winform datagird怎么分页 谢谢 我要代码
------解决方案--------------------http://support.microsoft.com/default.aspx?scid=kb;zh-cn;307710
------解决方案--------------------写存储过程呀。
------解决方案--------------------http://mxw1682.spaces.live.com/blog/cns!9ab6199f4b1f11e2!183.entry
------解决方案--------------------在数据库里实现分页SQL
------解决方案----------------------开始
CREATE PROCEDURE GetRecordFromPage
@tblName varchar(255), -- 表名
@fldName varchar(255), -- 字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@IsCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1000) = ’’ -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(1000) -- 主语句
declare @strTmp varchar(300) -- 临时变量
declare @strOrder varchar(400) -- 排序类型
if @OrderType != 0
begin
set @strTmp = " <(select min "
set @strOrder = " order by [ " + @fldName + "] desc "
end
else
begin
set @strTmp = "> (select max "
set @strOrder = " order by [ " + @fldName + "] asc "
end
set @strSQL = "select top " + str(@PageSize) + " * 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) + " * 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) + " * from [ "
+ @tblName + "] " + @strTmp + " " + @strOrder
end
if @IsCount != 0
set @strSQL = "select count(*) as Total from [ " + @tblName + "] "
exec (@strSQL)
GO
--结束
------解决方案--------------------Google 吴旗娃的分页控件 里面有例子,用到了sqlserver的新函数效率挺高的。
------解决方案--------------------哇,这问题就给100分,好大方呀
嘎嘎
数据多写存储过程,不多就不用写了
你数据多不多?
------解决方案--------------------存储过程分页