快速业务通道

Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-21

返回“ASP.NET 2.0数据教程目录”

导言

在上一章的教程中,我们看了GridView、DetailsView和FormView 绑定到OjbectDataSource控件显示数据,ObjectDataSource调用了类ProductsBLL 的GetProducts()方法。方法GetProducts()返回一个有Northwind数据库的 Products表的所有记录组成的强类型数据表。类ProductsBLL还包含了其它返回部 分数据的方法:GetProductByProductID(productID), GetProductsByCategoryID(categoryID), 和 GetProductsBySupplierID (supplierID) 。这三个方法要求输入一个参数来指示如何筛选返回的产品信息数据。

ObjectDataSource可以调用需要传入参数的方法,不过为了实现这一 点,我们需要指定这些参数从哪里获取值。这些参数的值可以通过硬代码传入, 也可以从某类来源动态地获取,包括:查询字符串的值(QueryString),会话变 量(Session variables),页面上控件的属性值,或者其它。

在这一章 的教程里,让我们开始举例说明如何使用参数设置一个硬编码的值。特别地,我 们将着眼于添加一个DetailsView到页面来显示一个名为Chef Anton’s Gumbo Mix的特殊产品,它的ProductID是5 。下一步,我们将看看如何基于Web控 件设置参数的值。特别地,我们将使用一个TextBox让用户键入国家(country) ,在点击某个按钮后列出驻该国家的供应商。

使用一个硬编码参数值

第一个例子,首先添加一DetailsView控件到BasicReporting文件夹里的 DeclarativeParams.aspx页面。从DetailsView控件的智能标记的下拉列表中选择 <新建数据源…>,然后选择添加一个ObjectDataSource 。

Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数

图 1: 添加一个ObjectDataSource到页面

这将自动打开 ObjectDataSource控件的配置数据源导航。在第一屏的导航中选择类ProductsBLL 。

Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数

图 2: 选择类ProductsBLL

既然我们要显示一个特定的产品的信 息,我们应该使用GetProductByProductID(productID)方法。

Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数

图 3: 选择GetProductByProductID(productID) 方法

因为我们 选择了这个包含参数的方法,导航就多了一屏,在这一屏要求我们定义参数所用 的值。在左边的列表中显示我们指定方法的所有参数。对于 GetProductByProductID(productID)方法则只有一个参数:productID 。在右边 的参数源下拉列表中列举出有可能被作为参数源的几类参数值。既然我们要指定 一个硬编码的值5用作productID参数,就让参数源选项是None并在DefaultValue 输入框键入5 。

Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数

图 4: 参数productID使用硬编码的值

完成了配置数据源向导后 ,ObjectDataSource控件的声明标记里就包含了一个SelectParameters集合,每 一个SelectMethod属性里指定的方法的参数都对应一个Parameter对象。既然我们 这个例子中的方法只要求一个参数parameterID ,那么SelectParameters集合里 也就只有一个元素。SelectParameters集合可以包含任何来源于 System.Web.UI.WebControls命名空间的类。因为是硬编码参数值所以使用基本的 Parameter类;如果需要的话你也可以创建自定义参数类型(custom parameter types)。

<asp:ObjectDataSource ID="ObjectDataSource1" runat="server"
   SelectMethod="GetProductByProductID" TypeName="ProductsBLL">
   <SelectParameters>
    <asp:Parameter DefaultValue="5" Name="productID" Type="Int32" />
  </SelectParameters>
</asp:ObjectDataSource>

注意:如果你在自己的电脑上 跟随这些步骤声明标记,你可能会看见这里包含InsertMethod,UpdateMethod和 DeleteMethod 的参数值,比如DeleteParameters 。ObjectDataSource的选择数 据源向导自动

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号