用ObjectDataSource实现自定义分页的心得总结

在Web应用开发中列表的分页是难免要遇到的问题,在ASP.NET 2.0中微软为我们提供了很多数据源控件,如SqlDataSource、ObjectDataSource等,它们都可以实现默认分页,但是默认分页是在内存中实现的,用户量增大时Web服务器的负担会急剧增大,在多层体系结构程序开发中,往往把分页和排序的工作交给数据库服务器来完成,在网上也能找到很多能够快速实现分页的控件,但是做为一个程序员对分页的实现还是有一定的了解比较好,如果过渡的依赖于控件,你说写出的代码独立性就很差,一般在多层web应用开发中建议尽量使用ObjectDataSource,而不要使用SqlDataSource,因为 
ObjectDataSource有一下有点: 

1、SqlDataSource是针对Sql Server的,对其他的数据库支持不够,例如在访问Oracle数据库时,要用存储过程返回结构集合SqlDataSource显得无能为力。 

2、ObjectDataSource 提供一个 TypeName 属性(而不是 ConnectionString属性),该属性指定用于执行数据操作的业务逻辑类的类名,ObjectDataSource可以通过TypeName 属性直接调用业务层的类,在多层应用中ObjectDataSource 显得很实用,而SqlDataSource要在页面上指定ConnectionString、Command,系统的层次结构被搞乱,不便于系统的维护工作。 

3、ObjectDataSource 控件提供了EnablePaging属性、SelectCountMethod属性、StartRowIndexParameterName属性和MaximumRowsParameterName属性专门支持数据源分页。 SelectCountMethod属性指定的是获取数据项总数的方法。StartRowIndexParameterName属性用于指定一个参数的名称,如程序中不特别设定,其默认参数名为startRowIndex,该参数代表该页数据项的开始行索引;MaximumRowsParameterName属性也用于指定一个参数名称,其默认参数名为maximumRows,该参数代表一页中容纳的数据项总数。SqlDataSource完全没有提供这些功能。 

4、SqlDataSource只支持内存分页,而不支持数据库分页,ObjectDataSource 两者都支持,内存分页每次都检索出所有数据并将其绑定到数据绑定控件中,虽然该控件只能一页一页显示这些数据,但是所有数据其实都已经被绑定到控件上了。而数据库分页的含义是显示到哪一页就检索并绑定哪一页的数据。显然在大数据量的情况下,数据库分页的效率会高很多。 

关于分页方法 

很多人写分页的方法喜欢创建临时表,虽然这是一个快捷的实现方法,但这样做效率肯定很低,其实在SQL Server和Oracle中分别使用Top和ROWNUM可以很方便的使用排序,充分利用数据库服务器来做计算可以降低web服务的负担。 

SQL Server的分页代码: 

复制   保存
SET QUOTED_IDENTIFIER ON 
GO
SET ANSI_NULLS ON 
GO

ALTER    proc SelectByPage(@startRowIndex int,@maximumRows int,@SortBy varchar(50))
as
declare @TotalCnt int
declare @sql varchar(8000)
begin
select @TotalCnt = count(*) from sys_user
set @sql = 'select top ' + convert(varchar(20),@maximumRows) + ' * from '
set @sql = @sql + '('
set @sql = @sql + '  select top ' + convert(varchar(20),(@TotalCnt-@startRowIndex)) + ' * from sys_user a '
set @sql = @sql + '  order by a.' + @SortBy + ' desc '
set @sql = @sql + ') b'
set @sql = @sql + ' order by b.' + @SortBy
exec(@sql)
--print @sql
end

GO
SET QUOTED_IDENTIFIER OFF 
GO
SET ANSI_NULLS ON 
GO

Oracle中的分页方法: 
复制   保存
/* Formatted on 2007/04/16 11:16 (Formatter Plus v4.8.8) */
CREATE OR REPLACE PROCEDURE diswebuser.select_by_page (
   p_start_page   NUMBER,
   p_page_size    NUMBER,
   p_sort_by      VARCHAR2
)
AS
   v_cnt           INTEGER;
   v_sql           VARCHAR2 (4000);
   v_start_index   INTEGER;
   v_end_index     INTEGER;
BEGIN
   SELECT COUNT (*)
     INTO v_cnt
     FROM side_slope;

   --v_start_index := (p_start_page - 1) * p_page_size + 1;
   v_start_index := p_start_page + 1;
   v_end_index := p_start_page + p_page_size;
   v_sql := v_sql || 'SELECT   * ';
   v_sql := v_sql || '    FROM (SELECT   ROWNUM AS row_id, a.* ';
   v_sql := v_sql || '              FROM side_slope a ';
   v_sql := v_sql || '          ORDER BY side_slope_id) ';
   v_sql :=
         v_sql
      || '   WHERE row_id BETWEEN '
      || TO_CHAR (v_start_index)
      || ' AND '
      || TO_CHAR (v_end_index)
      || '  ';
   v_sql := v_sql || 'ORDER BY side_slope_id ';
   DBMS_OUTPUT.put_line (v_sql);
END;
/


当然在Oracle存储中返回结构集要使用ref cursor,使用Oracle的朋友一定很清楚,我在这里就不罗嗦了,那样写还得创建包,麻烦^_^,上面只是打印出了sql语句。 
还望高手指点

 

 

源文是:http://www.cnblogs.com/yhlwsg/archive/2008/08/17/1269681.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值