| 加入收藏| 设为首页| 联系我们

首页 站长学习 站长之家 源码下载 建站素材 书籍教程 常用工具
 您现在的位置: 动力中国 >> 网络编程 >> ASP.NET教程 >> 文章正文  
 ASP.NET 2.0高级数据处理之处理Null值
 

ASP.NET 2.0高级数据处理之处理Null值

http://www.domcn.org  文章来源:本站收藏  点击数:

  关键字:ASP.NET 2.0高级数据处理之处理Null值

  数据控件支持多种用于处理空值或缺失数据的方法。例如,GridView、FormView和DetailsView都支持EmptyDataText或EmptyDataTemplate属性,当数据源没有返回数据行的时候,你可以使用这些属性来指定控件显示的内容。我们只需要设置EmptyDataText和EmptyDataTemplate其中的一个(如果两个都设置了,EmptyDataTemplate会被重载)。你也可以在绑定字段(和衍生的字段类型)、模板字段或数据源参数对象上指定ConvertEmptyStringToNull属性,指明在调用相关的数据源操作之前,来自客户端的String.Empty值必须被转换为空值。

  ObjectDataSource也支持ConvertNullToDbNull属性,当相关的方法要求用DbNull代替空值(Visual Studio数据集中的TableAdapter类就有这个要求)的时候,我们就可以把这个属性设置为真。你还可以指定绑定字段(和衍生的字段类型)的NullDisplayText属性,当数据源返回的某个字段的值为空的时候,它指定显示的内容。如果在编辑模式中这个值没有发生变化,那么在更新操作中这个值会以空值的形式返回给后端数据源。最后,你还可以指定数据源参数的DefaultValue属性,如果某个传递进来的参数值为空的时候,该属性就给参数指定默认值。这些属性是链式反应的,例如,如果ConvertEmptyStringToNull和DefaultValue都被设置了,那么String.Empty值会首先被转换为空(null),接着被转换为默认值。

<asp:DetailsView…...>
 <Fields>
  <asp:BoundField DataField=Phone HeaderText=Phone NullDisplayText=not listed SortExpression=Phone />
  <asp:BoundField DataField=Fax HeaderText=Fax NullDisplayText=not listed SortExpression=Fax />
 </Fields>
 <EmptyDataTemplate>
  <asp:Image ID=Image1 runat=server ImageUrl=~/Images/warning.gif />There are no records to display
 </EmptyDataTemplate>
</asp:DetailsView>
<asp:SqlDataSource ……>
 <UpdateParameters>
  <asp:Parameter Name=ContactTitle Type=String DefaultValue=Owner ConvertEmptyStringToNull=true />
  <asp:Parameter Name=Region Type=String ConvertEmptyStringToNull=true />
  <asp:Parameter Name=Phone Type=String ConvertEmptyStringToNull=true />
  <asp:Parameter Name=Fax Type=String ConvertEmptyStringToNull=true />
  <asp:Parameter Name=CustomerID Type=String />
 </UpdateParameters>
 ……
</asp:SqlDataSource>

  你可以使用这些处理空值的属性来实现下拉列表过滤器,让它开始时显示数据源的所有值,直到过滤器中的某个值被选中为止。我们是这样实现它的:首先给下拉列表添加一个空字符串值的数据项,并设置数据源中的与下拉列表相关的ControlParameter(控件参数)的ConvertEmptyStringToNull属性。

  接着在数据源的SelectCommand中,你可以通过检测空值来返回所有(没有过虑)值。下面的例子演示了这种技术,它使用了一个简单的SQL命令,当然你也可以在存储过程的实现中执行空值检测。请注意下拉列表的AppendDataBoundItems属性的使用,它允许来自下拉列表数据源的值被添加到ALL(这个项是我们静态添加的)数据项后面。同时我们要注意,在默认情况下,如果传递给SelectCommand 的相关参数的值中只要有一个为空,SqlDataSource就不执行Select操作。当传递了空值的时候,为了强制Select操作执行,你可以把它的CancelSelectOnNullParameter属性设置为假。

<asp:DropDownList AppendDataBoundItems=True AutoPostBack=True DataSourceID=SqlDataSource2 DataTextField=state DataValueField=state ID=DropDownList1 runat=server>
 <asp:ListItem Value=>ALL</asp:ListItem>
</asp:DropDownList>
<asp:SqlDataSource ConnectionString=<%$ ConnectionStrings:Pubs %> ID=SqlDataSource2 runat=server SelectCommand=SELECT DISTINCT [state] FROM [authors]>
</asp:SqlDataSource>

<asp:SqlDataSource ConnectionString=<%$ ConnectionStrings:Pubs %> ID=SqlDataSource1 runat=server SelectCommand=SELECT au_id, au_lname, au_fname, state FROM authors WHERE state = IsNull(@state, state) CancelSelectOnNullParameter=False>
<SelectParameters>
 <asp:ControlParameter ControlID=DropDownList1 Name=state PropertyName=SelectedValue Type=String />
</SelectParameters>
</asp:SqlDataSource>


ASP.NET 2.0高级数据处理之处理Null值
  • 上一篇文章:

  • 下一篇文章:
  •  热门文章
    普通文章 电子邮件改头换面 四公司畅谈未
    普通文章 PC病毒史上最声名狼藉的八大病
    普通文章 Rails系统中的AJAX开发技术简析
    普通文章 基于ASP.NET AJAX框架实现表单
    普通文章 开发ASP.NET AJAX客户端定制行
    普通文章 用JFreeChart对JSP报表进行增强
    普通文章 SQL Server 2005上的CLR和ADO.
    普通文章 SQL Server 2005的XML支持机制
    普通文章 Firefox中标签式浏览技巧大全
    普通文章 Tomcat中的Session和Cookie大揭
     
     推荐文章
    推荐文章 把Google地图嵌入网页 就是这么
    推荐文章 迅雷搜索候选资源出错的解决
    推荐文章 轻松去除迅雷里的各种广告和资
    推荐文章 突破限制 免费领养到QQ空间五级
    推荐文章 Rational统一过程RUP贴近中小软
    推荐文章 构建自己的轻量级XML DOM分析程
    推荐文章 WPS Office 2007技巧:妙用配置
    推荐文章 Excel 2007:求余数函数实用进阶
    推荐文章 浅谈ASP.NET的Postback
    推荐文章 软件开发中项目需求管理简述
     
     相关文章
    没有相关文章
    设为首页 | 加入收藏 | 广告合作 | 联系站长 | 版权申明 |
    动力中国为网友提供免费学习资料,可用资源,如果您认为我们的相关内容侵害到了您的权利请联系管理员
    Copyright © 2006-2008 domcn.org All Rights Reserved.