首页 / 网页编程 / ASP.NET / ASP.NET 2.0高级数据处理之处理Null值
ASP.NET 2.0高级数据处理之处理Null值2010-12-08 天极 陶刚数据控件支持多种用于处理空值或缺失数据的方法。例如,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>