一起谈.NET技术,asp.net控件开发基础(23)

简介:   讨论了如何实现一个简单的数据源控件,但还没有完全的实现.这次我们具体的实现一些方法来加强数据源控件的功能.这里我们根据SqlDataSource控件的一些功能来实现。本篇示例源码来自Professional ASP.NET2.0 ServerControl and Component Development,即是模仿SqlDataSource而制作.我把控件功能减弱,代码整理了下,我们只关注重要的部分,一步一步上去。

  讨论了如何实现一个简单的数据源控件,但还没有完全的实现.这次我们具体的实现一些方法来加强数据源控件的功能.这里我们根据SqlDataSource控件的一些功能来实现。本篇示例源码来自Professional ASP.NET2.0 ServerControl and Component Development,即是模仿SqlDataSource而制作.我把控件功能减弱,代码整理了下,我们只关注重要的部分,一步一步上去。

  一.概念

  1.首先你必须熟悉ADO.NET的使用,然后抽象出一部分属性和方法,如执行sql语句命令类型,这个属性你便可以抽象出来,当是控件功能的一部分.所以这部分代码不再列出,大家仔细看就会明白了。

  2.数据操作注意事项

  (1)数据前后操作事件,我们见过SqlDataSource的数据前后操作事件,如读取数据,前后事件则是Selecting和Selected

假设getData方法是读取数据库,那么写成代码就是这样

 
  
protected override IEnumerable ExecuteSelect(DataSourceSelectArguments arguments)
{
SqlDataSourceSelectingEventArgs e
= new SqlDataSourceSelectingEventArgs(com, arguments);
// 尝试数据检索操作前引发 Selecting 事件
OnSelecting(e);
return getData();
SqlDataSourceStatusEventArgs ee
= new SqlDataSourceStatusEventArgs(com, - 1 , null );
// 尝试数据检索操作后引发 Selecting 事件
OnSelected(ee);
}

其他数据操作也一样

  (2)自动重新绑定

  读取数据是基本的,不存在对数据库的更改,当对数据进行增,删,改时.数据发生了变化,以前我们则是手动进行重新绑定,现在也是,只不过方式变了而已.DataSourceView中存在OnDataSourceViewChanged 方法,我们只需要调用这个方法引发DataSourceViewChanged事件通知数据发生了变化,就会帮你自动重新绑定了,即除了读取数据以外的其他数据操作都需要调用这个方法.假设是删除操作,则代码如下

 
  
protected override int ExecuteDelete(IDictionary keys, IDictionary oldValues)
{
SqlDataSourceCommandEventArgs e
= new SqlDataSourceCommandEventArgs(com);
OnDeleting(e);
affectedRows
= com.ExecuteNonQuery();
OnDataSourceViewChanged(EventArgs.Empty);
SqlDataSourceStatusEventArgs ee
= new SqlDataSourceStatusEventArgs(com, affectedRows, exception);
OnDeleted(ee);
return affectedRows;
}

  (3)Can属性

  指定能否进行数据操作,读取数据默认可以,其他的操作可以在方法开始部分加上如下代码,假设是不支持删除操作

       protected   override   int  ExecuteDelete(IDictionary keys, IDictionary oldValues)
      
{
          
if (!CanDelete)
              
throw new NotSupportedException("不支持删除操作");
      }

  (4)数据检索额外操作

  数据源控件还可以提供额外的数据操作,如排序,分页等

  DataSouceView的ExecuteSelect方法里的参数正是DataSourceSelectArguments类型,可以通过其AddSupportedCapabilities方法添加功能,然后调用RaiseUnsupportedCapabilitiesError方法检测操作要求与实现是否符合(即你指定了排序的功能,但数据源控件并未实现这个操作,防止弄虚做假的事情出现,核对一下功能:))。当然前提是数据源提供这样的功能实现,注意DataSourceSelectArguments类的属性与支持功能相对应,大家可以查看MSDN。

代码如下

      protected   override  IEnumerable ExecuteSelect(DataSourceSelectArguments arguments)
      
{
          arguments.AddSupportedCapabilities(DataSourceCapabilities.Page);
          arguments.AddSupportedCapabilities(DataSourceCapabilities.Sort);
          arguments.RaiseUnsupportedCapabilitiesError(
this);
      }

  接着还要重写DataSourceView的RaiseUnsupportedCapabilityError方法

 
  
protected override void RaiseUnsupportedCapabilityError(DataSourceCapabilities capability)
{
if ((((capability & DataSourceCapabilities.Page) != 0 ) && ! CanPage) ||
(((capability
& DataSourceCapabilities.RetrieveTotalRowCount) != 0 ) && ! CanRetrieveTotalRowCount) ||
(((capability
& DataSourceCapabilities.Sort) != 0 ) && ! CanSort))
throw new NotSupportedException();

base .RaiseUnsupportedCapabilityError(capability);
}

  (5)执行数据操作(同步与异步)

  ExecuteInsert等方法为具体实现Insert方法则负责调用,其DataSourceView类支持数据的异步操作,如

public   virtual   void  Insert (
    IDictionary values,
    DataSourceViewOperationCallback callback
)

  但默认情况下是同步的,所以还需要在子类实现一个同步的方法

       public   int  Insert(IDictionary values)
      
{
          
return ExecuteInsert(values);
      }

  以上是我认为值得注意的地方。DataSourceView类就是一个干活的类.反而DataSourceControl差不多什么也没做,只调用DataSourceView的相关方法.其只为DataSourceView类提供了ConnectionString属性(数据连接字符串).
DataSourceControl实现了IDataSource接口,当数据源发生变化时,则需要调用IDataSource接口的DataSourceChanged事件,DataSourceControl提供了RaiseDataSourceChangedEvent方法调用,如修改了ConnectionString属性就需要调用此方法,如

public   virtual   string  ConnectionString
{
    
get
    
{
        
if (this._connectionString != null)
        
{
            
return this._connectionString;
        }

        
return string.Empty;
    }

    
set
    
{
        
if (this.ConnectionString != value)
        
{
            
this._connectionString = value;
            
this.RaiseDataSourceChangedEvent(EventArgs.Empty);
        }

    }

}

  以上为我学习方法的总结,都是比较重要的地方。如果列代码的话,不适合.因为大家数据库操作本来就会的。熟悉上面的操作过程然后再进行编写就好多了。还希望与大家多交流,错误的地方还请指出。

上一篇:asp.net控件开发基础(22)
目录
相关文章
|
人工智能 芯片
D1net阅闻|OpenAI员工疯狂暗示,内部已成功开发ASI?被曝训出GPT-5但雪藏
D1net阅闻|OpenAI员工疯狂暗示,内部已成功开发ASI?被曝训出GPT-5但雪藏
|
11月前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
461 0
|
Linux API C#
基于 .NET 开发的多功能流媒体管理控制平台
基于 .NET 开发的多功能流媒体管理控制平台
255 9
|
Web App开发 前端开发 调度
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
234 8
|
前端开发 JavaScript C#
基于.NET8+Vue3开发的权限管理&个人博客系统
基于.NET8+Vue3开发的权限管理&个人博客系统
222 7
|
前端开发 NoSQL .NET
一起谈.NET技术,重构TekPub——从ASP.NET MVC框架迁移到Ruby on Rails
  TekPub是一个面向开发人员的站点,致力于为开发人员提供一系列主题的在线培训,主题范围非常广泛,从微软的O/R Mapping框架Microsoft Entity Framework,到如何使用Ruby on Rails技术编写自己的日志引擎等内容都有涉及。
1777 0
|
Web App开发 SQL 前端开发
一起谈.NET技术,鲜为人知的ASP.NET MVC 2.0框架高效之谜
  要想建立开发环境,你需要安装Visual Studio 2008/2010 Beta 2,以及SQL Express 2005(可免费从MSDN下载)和MVC 2.0框架。我把本文中的示例Web应用命名为“Employee Master Information”。
1108 0
|
存储 缓存 .NET
一起谈.NET技术,提高ASP.NET应用程序性能的十大方法
  一、返回多个数据集   检查你的访问数据库的代码,看是否存在着要返回多次的请求。每次往返降低了你的应用程序的每秒能够响应请求的次数。通过在单个数据库请求中返回多个结果集,可以减少与数据库通信的时间,使你的系统具有扩展性,也可以减少数据库服务器响应请求的工作量。
1321 0
|
Web App开发 .NET 数据库
一起谈.NET技术,ASP.NET中如何正确使用Session
  Asp.Net中的Session要比Asp中的Session灵活和强大很多,同时也复杂很多;看到有一些Asp.Net开发人员报怨说Session不稳定,莫名其妙的丢失,其实这正是Asp.Net改进的地方之一。
1145 0
|
Web App开发 缓存 .NET
一起谈.NET技术,ASP.NET缓存全解析4:应用程序数据缓存
  ASP.NET缓存全解析文章索引 ASP.NET缓存全解析1:缓存的概述 ASP.NET缓存全解析2:页面输出缓存 ASP.NET缓存全解析3:页面局部缓存 ASP.NET缓存全解析4:应用程序数据缓存 ASP.NET 缓存全解析5:文件缓存依赖 ASP.NET 缓存全解析6:数据库缓存依赖 ASP.NET 缓存全解析7:第三方分布式缓存解决方案 Memcached和Cacheman   System.Web.Caching 命名空间提供用于缓存服务器上常用数据的类。
1042 0