Scott Mitchell的ASP.NET 2.0数据教程之五:声明参数
返回“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 。 图 1: 添加一个ObjectDataSource到页面 这将自动打开 ObjectDataSource控件的配置数据源导航。在第一屏的导航中选择类ProductsBLL 。 图 2: 选择类ProductsBLL 既然我们要显示一个特定的产品的信 息,我们应该使用GetProductByProductID(productID)方法。 图 3: 选择GetProductByProductID(productID) 方法 因为我们 选择了这个包含参数的方法,导航就多了一屏,在这一屏要求我们定义参数所用 的值。在左边的列表中显示我们指定方法的所有参数。对于 GetProductByProductID(productID)方法则只有一个参数:productID 。在右边 的参数源下拉列表中列举出有可能被作为参数源的几类参数值。既然我们要指定 一个硬编码的值5用作productID参数,就让参数源选项是None并在DefaultValue 输入框键入5 。 图 4: 参数productID使用硬编码的值 完成了配置数据源向导后 ,ObjectDataSource控件的声明标记里就包含了一个SelectParameters集合,每 一个SelectMethod属性里指定的方法的参数都对应一个Parameter对象。既然我们 这个例子中的方法只要求一个参数parameterID ,那么SelectParameters集合里 也就只有一个元素。SelectParameters集合可以包含任何来源于 System.Web.UI.WebControls命名空间的类。因为是硬编码参数值所以使用基本的 Parameter类;如果需要的话你也可以创建自定义参数类型(custom parameter types)。
注意:如果你在自己的电脑上 跟随这些步骤声明标记,你可能会看见这里包含InsertMethod,UpdateMethod和 DeleteMethod 的参数值,比如DeleteParameters 。ObjectDataSource的选择数 据源向导自动 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |