ASP.NET 2.0数据教程:给DataRow添加字段级验证
创始人
2024-04-20 09:11:08
0

给DataRow添加字段级验证是指在插入或更新时检查业务对象所涉及到的所有属性值。拿产品来举个例,某些字段级的验证规则如下所示:

 ·         ProductName字段不得超过40个字符

·         QuantityPerUnit字段不得超过20个字符

·         ProductID、ProductName以及Discontinued字段是必填的,而其他字段则是可填可不填的

·         UnitPrice、UnitsInStock、UnitsOnOrder以及ReorderLevel字段不得小于0

这些规则可以或者说是应该在数据库层被描述出来。ProductName和QuantityPerUnit字段上的字符数限制可以通过Products表中相应列的数据类型来实现(分别为nvarchar(40) and nvarchar(20))。字段“是否必填”可以通过将数据库中表的相应列设置为“允许为NULL”来实现。为了保证UnitPrice、UnitsInStock、UnitsOnOrder以及ReorderLevel字段的值不小于0,可以分别在它们的相应列上加一个约束。

除了在数据库中应用了这些规则之外,它们同时也将被其应用在DataSet上。事实上,字段长度和是否允许为空等信息已经被应用到了各DataTable的DataColumn集合中。我们可以在数据集设计器(DataSet Designer)中看到已经存在的字段级验证,从某个DataTable中选择一个字段,然后在属性窗口中就可以找到了。如图四所示,ProductDataTable中的QuantityPerUnit字段允许空值并且***长度为20各字符。如果我们试图给某个ProductsDataRow的QuantityPerUnit属性设置一个长度大于20个字符的字符串,将会有一个ArgumentException被抛出。

DataColumn提供了基本的字段级验证 

图四:DataColumn提供了基本的字段级验证

不幸的是,我们不能通过属性窗口指定一个边界检查,比如UnitPrice的值不能小于0。为了提供这样的字段级验证,我们需要为DataTable的ColumnChanging事件建立一个Event Handler。正如上一节教程中所提到的那样,由类型化数据集创建的DataSet、DataTable还有DataRow对象可以通过partial类来进行扩展。使用这个技术,我们可以为ProductDataTable创建一个ColumnChanging的Event Handler。我们先在App_Code文件夹中新建一个名为ProductsDataTable.ColumnChanging.cs的类文件,如下图所示。

在App_Code文件夹中添加新类 

图五:在App_Code文件夹中添加新类

然后,给ColumnChanging事件创建一个Event handler,以保证UnitPrice、UnitsInStock、UnitsOnOrder以及ReorderLevel字段的值不小于0。如果这些列的值超出范围就抛出一个ArgumentException。

  1. public partial class Northwind    
  2. {    
  3.     public partial class ProductsDataTable    
  4.     {    
  5.         public override void BeginInit()    
  6.          {    
  7.             this.ColumnChanging += ValidateColumn;    
  8.          }    
  9.    
  10.          void ValidateColumn(object sender, DataColumnChangeEventArgs e)    
  11.          {    
  12.             if(e.Column.Equals(this.UnitPriceColumn))    
  13.             {    
  14.                if(!Convert.IsDBNull(e.ProposedValue) && (decimal)e.ProposedValue <  0)    
  15.                {    
  16.                   throw new ArgumentException("UnitPrice cannot be less than zero", "UnitPrice");    
  17.                }    
  18.             }    
  19.             else if (e.Column.Equals(this.UnitsInStockColumn) ||    
  20.                     e.Column.Equals(this.UnitsOnOrderColumn) ||    
  21.                    e.Column.Equals(this.ReorderLevelColumn))    
  22.             {    
  23.                 if (!Convert.IsDBNull(e.ProposedValue) && (short)e.ProposedValue <  0)    
  24.                 {    
  25.                     throw new ArgumentException(string.Format("{0} cannot be less than zero", e.Column.ColumnName), e.Column.ColumnName);    
  26.                 }    
  27.             }    
  28.          }    
  29.     }    
  30. }   

这样就实现了asp.net 2.0数据操作中的业务逻辑层的第三步:给DataRow添加字段级验证。

【编辑推荐】

  1. 如何在IIS6.0中部署asp.net mvc程序
  2. 用Winform傻瓜式搭建asp.net mvc框架
  3. ASP.NET Session失效的编程思路
  4. ASP.NET Session 状态的存储
  5. 了解ASP.NET Web应用程序模型

                 
            

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...