六编程设置ObjectDataSource的参数值_第1页
六编程设置ObjectDataSource的参数值_第2页
六编程设置ObjectDataSource的参数值_第3页
六编程设置ObjectDataSource的参数值_第4页
六编程设置ObjectDataSource的参数值_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、在ASP.NET 2.0中操作数据之六:编程设置ObjectDataSource的参数值作者:heker2007 字体:增加 减小 类型:转载 时间:2016-04-29 我要评论本文主要介绍在ObjectDataSource控件的Selecting事件中,设置InputParameters参数,配合业务层的查询方法,以达到查询不同数据的目的。导言正如我们在上一节的教程中所看到的,有很多可供选择的方式把参数的值传递到OjbectDataSource的方法里。假如参数值是采用硬编码方式,来源于页面上的一个Web控件,又或者其他可被数据源Parameter对象读取的源,那么这个

2、值可以绑定到输入参数而不需要写一行的代码。然而有些时候,参数值来自某些在数据源的内置Parameter对象里还没有计算出来的源。假如我们的站点支持我们的考虑那么我们也许希望参数基于当前登录用户。又或者我们在参数传送到ObjectDataSource的隐含对象的方法前做一些客户化定制。无论什么时候调用ObjectDataSource的Seelect方法,它都会首先触发它的Selecting事件,然后才调用ObjectDataSource的隐含对象的方法,完成后则激发ObjectDataSource ObjectDataSource的Selected 事件(图一说明这些事件的顺序)。可以在Sele

3、cting事件的事件委托中对参数的值进行设置或更改。图 1: ObjectDataSource的Selected 和 Selecting 事件分别在调用它的隐含对象的方法之前和之后触发这一节里我们将看看添加一个接受一个输入参数方法到DAL和BLL层,参数名为Month,int类型,方法返回一个EmployeesDataTable对象,里边包含的是雇佣周年纪念都指定月份的雇员。我们的例子将编码设置为基于当前月份,显示一个“本月雇用周年纪念员工”列表。让我们开始吧!第一步: 添加一个方法到 EmployeesTableAdapter在我们的第一个例子里,我们需要添加一个方法来获取那些雇用日期(Hi

4、reDate)在某个指定月份的员工。在我们的程序架构下为了提供这个功能,我们首先需要在通过特定SQL语句映射出来的EmployeesTableAdapter中创建一个方法。为了实现这一点,首先打开Northwind类型化数据集,在EmployeesTableAdapter标签上右键选择“添加查询”。图 2: 在 EmployeesTableAdapter里添加一个查询选择返回一个或多个行和列的SQL语句。当到达指定SELECT语句窗口时,EmployeesTableAdapter已经装载了默认的SELECT语句。简单地,添加一个WHERE子句:WHERE DATEPART(m, HireDat

5、e) = Month 。其中DATEPART是T-SQL里的一个函数,用作返回日期类型的一部分;在这里,我们使用DATEPART函数返回雇用日期(HireDate)列的月份部分。图 3: 仅返回 HireDate 列的值小于等于参数 HiredBeforeDate的行最后,分别把默认的方法名FillBy和GetDataBy更改为FillByHiredDateMonth和GetEmployeesByHiredDateMonth 。图 4: 选择比FillBy和GetDataBy更恰当的方法名称 点击“完成”结束向导并返回到数据集的设计界面。这时候EmployeesTableAdapte

6、r会包含一套新的方法来获取指定月份雇用的员工。图 5: 新的方法出现在数据集的设计界面第二步: 在业务逻辑层添加方法 GetEmployeesByHiredDateMonth(month)因为我们的程序架构使用了单独的一层来处理业务逻辑和数据逻辑,我们需要在BLL里增加一个方法,该方法调用DAL的方法获取指定月份里雇用的员工。打开文件EmployeesBLL.cs并添加下面这个方法:?123456789System.ComponentModel.DataObjectMethodAttribute(System.ComponentModel.DataObjectMethodType.Select

7、, false) public Northwind.EmployeesDataTable GetEmployeesByHiredDateMonth(int month)   return Adapter.GetEmployeesByHiredDateMonth(month); 和此类里的其他方法一样,GetEmployeesByHiredDateMonth(month)仅仅是简单地调用DAL并返回结果。第三步: 显示雇用周年纪念日在本月份的员工最后一部我们举例说明如何显示雇用周年纪念在本月份的员工。首先,添加一个GridView控件到页面Pro

8、grammaticParams.aspx,该页面在文件夹BasicReporting里。添加一个新的ObjectDataSource控件作为它的数据源。配置ObjectDataSource使用类EmployeesBLL并指定SelectMethod属性为GetEmployeesByHiredDateMonth(month)。图 6: 使用EmployeesBLL 类图 7: 选择GetEmployeesByHiredDateMonth(month)方法最后一屏要求我们给month参数提供参数源。既然我们将编码设置这个值,就让参数源维持它的默认选项None,点击“完成”。图 8: 让参数源设置为

9、None这将在ObjectDataSource的SelectParameters集合里创建一个未指定参数值的Parameter对象。?1234567891011<asp:ObjectDataSource ID="ObjectDataSource1" runat="server" OldValuesParameterFormatString="original_0"  SelectMethod="GetEmployeesByHiredDateMonth" TypeName="Emp

10、loyeesBLL">  <SelectParameters>   <asp:Parameter Name="month" Type="Int32" />  </SelectParameters> </asp:ObjectDataSource>要编码设置这个参数值,我们需要给ObjectDataSource的Selecting事件添加一个事件委托。为了实现这一点,到设计视图里在ObjectDataSource上双

11、击。另一种方式是选中ObjectDataSource在属性窗口里点击黄色闪电小图标,然后,直接在Selecting这一栏里双击或者输入一个你要使用的事件委托的名称。图 9:点击属性窗口里的闪电图标列出Web控件的所有事件两种途径都可以在页面的代码隐藏类里增加一个对ObjectDataSource的Selecting事件的事件委托。在这个事件委托里,我们可以通过使用e.InputParametersparameterName读取参数的值,其中parameterName的值是<asp:Parameter>标签里的属性Name的值(InputParameters也可以按照索引访问,用e.

12、InputParametersindex)。为了把month参数设置为当前月份,需要在Selecting事件委托里加入如下代码:?1234567protected void ObjectDataSource1_Selecting(object sender, ObjectDataSourceSelectingEventArgs e)   e.InputParameters"month" = DateTime.Now.Month; 当通过浏览器访问该页面,我们可以看到只有一个员工是在当前月份(三月)雇用的:Laura Callahan,他从1994年3月开始雇用。图 10: 雇用周年纪念日在本月份的员工被显示出来了总结虽然可以用特定的方式声

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论