快速业务通道

DataGrid基于Access的快速分页法

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-22
lt; (").Append(" SELECT MIN(");
sb.Append(primaryKey).Append(") FROM ( SELECT TOP ")
.Append(pageSize*pageIndex).Append(" ").Append(primaryKey)
.Append(" FROM ").Append(tableName);
if (condition != String.Empty)
sb.Append(" WHERE ").Append(condition);
sb.Append(" ORDER BY ").Append(primaryKey).Append(" ")
.Append(GetSortType(ascending)).Append(" ) TableA )");
if (condition != String.Empty)
sb.Append(" AND ").Append(condition);
sb.Append(" ORDER BY ").Append(primaryKey).Append(" ")
.Append(GetSortType(ascending));
}
else if (pageIndex > middleIndex && pageIndex < lastIndex) {
// 代码略
} else if (pageIndex >= lastIndex) {
// 代码略
}
return sb.ToString();
}
  除了Paging方法还有另外几个方法:
// 根据记录总数和分页大小计算分页数。
public static int GetPageCount(int recordCount, int pageSize) {
return (int)Math.Ceiling((double)recordCount/pageSize);
}
// 计算中间页的页索引。
public static int GetMidPageIndex(int pageCount) {
return (int)Math.Ceiling((double)pageCount/2) - 1;
}
// 获取排序的方式("ASC"表示升序,"DESC"表示降序)
public static String GetSortType(bool ascending) {
return (ascending ? "ASC" : "DESC");
}
// 获取一个布尔值,该值指示排序的方式是否为升序。
public static bool IsAscending(String orderType) {
return ((orderType.ToUpper() == "DESC") ? false : true);
}

让DataGrid工作起来

有了上面的类,实现分页的工作就简单多了。首先,我们要将DataGrid的AllowPaging属性和AllowCustomPaging属性为True,除此之外,为了体现出升序和降序的功能,还需要将AllowSorting属性也设置为True。然后在每次分页时,我们需要产生一个OleDbDataReader对象或DataView对象绑定到DataGrid,作为DataGrid的数据源。这里需要用FastPaging类的Paging方法根据条件产生一个SQL语句,并赋给OleDbCommand对象的CommandText属性:

cmd.CommandText = FastPaging.Paging(
DataGrid1.PageSize,
(int)ViewState["CurrentPageIndex"],
DataGrid1.VirtualItemCount,
"Items",
"ItemId, ProductId, Price",
"ItemId",
FastPaging.IsAscending(OrderType),
""
);

在上面的程序段中,ViewState["CurrentPageIndex"]的值在DataGrid的Page事件处理程序中被更新为e.NewPageIndex。为了方便处理ViewState的空值,最好把对ViewState["CurrentPageIndex"]的存取操作和空值判断封装在一个属性里。DataGrid1. VirtualItemCount应该设置为数据库表中的记录总数。DataGrid通过它和PageSize属性可以虚拟出DataGrid的分页数。VirtualItemCount的值是在Page的Load事件处理程序中被设置的,而该值的大小需要经过一次数据库访问才能得到。为了提高性能,可以只在第一次加载页面的时候设置该值。

总结

DataGrid基于Access的快速分页法到这里就介绍完了。当然,这种方法并不能“包治百病”,可能对于您的要实现的功能,还有其它更好的方法。这就需要大家在平时工作和学习中不断总结经验,在解决实际问题时尽可能找到最有效的方法。这也是本文的方法中所贯穿的思想。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号