温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

发布时间:2021-07-15 16:42:19 来源:亿速云 阅读:201 作者:Leah 栏目:开发技术

这篇文章将为大家详细讲解有关在ASP.NET 2.0中怎么设置ObjectDataSource的参数值,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

第一步: 添加一个方法到 EmployeesTableAdapter

  在我们的第一个例子里,我们需要添加一个方法来获取那些雇用日期(HireDate)在某个指定月份的员工。在我们的程序架构下为了提供这个功能,我们首先需要在通过特定SQL语句映射出来的EmployeesTableAdapter中创建一个方法。为了实现这一点,首先打开Northwind类型化数据集,在EmployeesTableAdapter标签上右键选择“添加查询”。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 2: 在 EmployeesTableAdapter里添加一个查询

  选择返回一个或多个行和列的SQL语句。当到达指定SELECT语句窗口时,EmployeesTableAdapter已经装载了默认的SELECT语句。简单地,添加一个WHERE子句:WHERE DATEPART(m, HireDate) = @Month 。其中DATEPART是T-SQL里的一个函数,用作返回日期类型的一部分;在这里,我们使用DATEPART函数返回雇用日期(HireDate)列的月份部分。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 3: 仅返回 HireDate 列的值小于等于参数 @HiredBeforeDate的行

最后,分别把默认的方法名FillBy和GetDataBy更改为FillByHiredDateMonth和GetEmployeesByHiredDateMonth 。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 4: 选择比FillBy和GetDataBy更恰当的方法名称

点击“完成”结束向导并返回到数据集的设计界面。这时候EmployeesTableAdapter会包含一套新的方法来获取指定月份雇用的员工。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 5: 新的方法出现在数据集的设计界面

第二步: 在业务逻辑层添加方法 GetEmployeesByHiredDateMonth(month)

  因为我们的程序架构使用了单独的一层来处理业务逻辑和数据逻辑,我们需要在BLL里增加一个方法,该方法调用DAL的方法获取指定月份里雇用的员工。打开文件EmployeesBLL.cs并添加下面这个方法:

[System.ComponentModel.DataObjectMethodAttribute(System.ComponentModel.DataObjectMethodType.Select, false)]

public Northwind.EmployeesDataTable GetEmployeesByHiredDateMonth(int month)

{

 return Adapter.GetEmployeesByHiredDateMonth(month);

}

和此类里的其他方法一样,GetEmployeesByHiredDateMonth(month)仅仅是简单地调用DAL并返回结果。

第三步: 显示雇用周年纪念日在本月份的员工

  最后一部我们举例说明如何显示雇用周年纪念在本月份的员工。首先,添加一个GridView控件到页面ProgrammaticParams.aspx,该页面在文件夹BasicReporting里。添加一个新的ObjectDataSource控件作为它的数据源。配置ObjectDataSource使用类EmployeesBLL并指定SelectMethod属性为GetEmployeesByHiredDateMonth(month)。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 6: 使用EmployeesBLL 类

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 7: 选择GetEmployeesByHiredDateMonth(month)方法

最后一屏要求我们给month参数提供参数源。既然我们将编码设置这个值,就让参数源维持它的默认选项None,点击“完成”。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 8: 让参数源设置为None

这将在ObjectDataSource的SelectParameters集合里创建一个未指定参数值的Parameter对象。

<asp:ObjectDataSource ID="ObjectDataSource1" runat="server" OldValuesParameterFormatString="original_{0}"

 SelectMethod="GetEmployeesByHiredDateMonth" TypeName="EmployeesBLL">

 <SelectParameters>

  <asp:Parameter Name="month" Type="Int32" />

 </SelectParameters>

</asp:ObjectDataSource>

  要编码设置这个参数值,我们需要给ObjectDataSource的Selecting事件添加一个事件委托。为了实现这一点,到设计视图里在ObjectDataSource上双击。另一种方式是选中ObjectDataSource在属性窗口里点击黄色闪电小图标,然后,直接在Selecting这一栏里双击或者输入一个你要使用的事件委托的名称。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

图 9:点击属性窗口里的闪电图标列出Web控件的所有事件

两种途径都可以在页面的代码隐藏类里增加一个对ObjectDataSource的Selecting事件的事件委托。在这个事件委托里,我们可以通过使用e.InputParameters[parameterName]读取参数的值,其中parameterName的值是<asp:Parameter>标签里的属性Name的值(InputParameters也可以按照索引访问,用e.InputParameters[index])。为了把month参数设置为当前月份,需要在Selecting事件委托里加入如下代码:

protected void ObjectDataSource1_Selecting(object sender, ObjectDataSourceSelectingEventArgs e)

{

 e.InputParameters["month"] = DateTime.Now.Month;

}

当通过浏览器访问该页面,我们可以看到只有一个员工是在当前月份(三月)雇用的:Laura Callahan,他从1994年3月开始雇用。

在ASP.NET 2.0中怎么设置ObjectDataSource的参数值

关于在ASP.NET 2.0中怎么设置ObjectDataSource的参数值就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI