快速业务通道

ASP.NET 2.0数据教程之四十八:在SqlDataSource中使用参数化查询

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-21
节教程以及本节教程前面的所有例 子中,我们都是直接将SqlDataSource控件绑定到GridView上的。其实, SqlDataSource中的数据可以通过编程的方式在代码中进行访问和枚举。在你需要 将数据查出来做某些处理而不是仅仅只是把它们显示出来的时候,这将特别有用 。你可以将诸如连接数据库、指定Commond以及获取数据等这些郁闷乏味的事情交 给SqlDataSource去处理,而不用自己编写所有的这些刻板的ADO.NET代码。

为了说明如何通过编程的方式使用SqlDataSource,想象一下,你的BOSS 叫你做一个可随机显示一个分类的名称及其相关的产品的网页(译者注:为了不 引起各位读者的误解,说明一下,这个例子跟boss一点关系都没有,估计作者也 是为了好玩吧^_^)。也就是说,当一个用户访问到了这个页面,我们需要随机的 从Categories表中选取一个分类,显示其名称,并将所有属于这个分类的产品都 列出来。

要达到这个目的,我们需要两个SqlDataSource控件,一个用来 从Categories表中随机选取一个分类,另一个用来获取这个分类的产品。我们将 在这个步骤中创建第一个SqlDataSource,第五步中将详细讲解如何创建第二个 SqlDataSource。

首先,我们需要向ParameterizedQueries.aspx中添加一 个SqlDataSource,将其ID设置为RandomCategoryDataSource,并配置它以使其使 用下面这个SQL语句:

1SELECT TOP 1 CategoryID, CategoryName
2FROM Categories
3ORDER BY NEWID()

“ORDER BY NEWID()”将返回随机排序的记录(参见 使用NEWID()进行随机排序)。“SELECT TOP 1”将返回记录集中的第 一项。把它们放到一起,即返回一个随机分类的CategoryID和CategoryName。

要显示分类的CategoryName,需要往页面上添加一个Label控件,将其ID 属性设置为CategoryNameLabel,并清除其Text属性。要通过编程的方式从 SqlDataSource控件中获取数据,我们需要调用其Select()方法。Select()方法需 要一个DataSourceSelectArguments类型的输入参数,它将指定数据在返回之前应 该被如何预处理(译者注:原文为messaged,真的不知道该怎么翻译, DataSourceSelectArguments其实主要还是给诸如GridView之类的控件使用的,具 体的使用方法请参看MSDN)。它可以包含一些排序或分页处理的说明,当数据Web 控件在对SqlDataSource控件的数据进行排序或分页时就可以使用了。不过在我们 的例子中,我们不需要数据在返回之前被进行任何的处理,所以我们传一个 DataSourceSelectArguments.Empty过去就可以了。

Select()方法将返回 一个实现了IEnumerable的对象。具体的返回类型取决于SqlDataSource控件的 DataSourceMode属性。上一节中已经讨论过了,它可以设置为DataSet或 DataReader。如果设置为DataSet,Select()将返回一个DataView对象;如果设置 为DataReader,则返回一个实现了IDataReader的对象。由于 RandomCategoryDataSource的DataSourceMode设置成了DataSet(这是默认值), 我们将会得到一个DataView对象。

下面的代码演示了如何从 RandomCategoryDataSource中以DataView的形式获取记录,还说明了如何从 DataView的第一行获取CategoryName列的值:

1protected void Page_Load(object sender, EventArgs e)
2{
3  // 从 SqlDataSource中以DataView的形式获取数据
4  DataView randomCategoryView =
5    (DataView) RandomCategoryDataSource.Select(DataSourceSelectArguments.Empty);
6
7  if (randomCategoryView.Count > 0)
8  {
9     // 将CategoryName的值赋给Label
10     CategoryNameLabel.Text =
11      string.Format("Here are Products in the {0} Category",
12         rand

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站: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号