快速业务通道

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-21
itPrice, [UnitsInStock] = @UnitsInStock,
  [UnitsOnOrder] = @UnitsOnOrder, [ReorderLevel] = @ReorderLevel,
  [Discontinued] = @Discontinued
WHERE (([ProductID] = @ProductID));

SELECT ProductID, ProductName, SupplierID, CategoryID, QuantityPerUnit,
  UnitPrice, UnitsInStock, UnitsOnOrder, ReorderLevel, Discontinued
FROM Products
WHERE (ProductID = @ProductID)

按Ctrl+S或点工具栏里的“保存”图标, 保存更改.此时,Products_Update存储过程不会执行@Original_ProductID参数, 但TableAdapter仍然会传递该参数.要想查看TableAdapter传递给 Products_Update存储过程的参数,你可以在设计器里选中TableAdapter,转到属 性窗口,点更新命令的参数集(UpdateCommand’sParameters collection) 里的椭圆型区域,这样将转到Parameters Collection Editor对话框,如图14所 示:

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图14:对话框里列出了传递给Products_Update存储过程的参数

要删除参数,只需选中它,再点Remove按钮.

要刷新参数的话,你也可以 在设计器里选中TableAdapter,点右键选“设置”,这将会开启 TableAdapter设置向导,它列出了用于select, insert, updat和delete的存储过 程,并列出了这些存储过程的输入参数.如果你在Update下拉列表里选 Products_Update的话,你可以看到该存储过程包含的输入参数里已经没有包含 @Original_ProductID了(见图15),点Finish将对TableAdapter使用的参数集自动 更新.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图15:你可以通过使用TableAdapter的设置向导来刷新参数集

第五步:添加额外的TableAdapter方法

我们在第二步说过,当创建一个新 的TableAdapter时,很容易自动地生成相应的存储过程,同样我们也可以向 TableAdapter添加额外的方法.作为演示,让我们向ProductsTableAdapter添加一 个方法GetProductByProductID(productID),该方法将一个ProductID作为输入参 数,并返回该产品的详细信息.在ProductsTableAdapter上点击右键,选择 “添加查询”.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图16:向TableAdapter添加新查询

这将开启TableAdapter查询 设置向导。首先,向导将询问以何种方式访问数据库,我们将创建一个新的存储 过程,因此选“Create a new stored procedure”,再点 Next.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图17:选中“Create a new stored procedure”项

接下来,向导询问我们执行哪种查询,是返回一系列行?一个标量值?又或者执 行UPDATE, INSERT,或 DELETE statement.由于GetProductByProductID (productID)方法将返回一行,我们选择“SELECT which returns row”项,再点Next.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图18:选择“SELECT which returns row” 项

接下 来的界面将展示TableAdapter的主查询,其仅仅列出了存储过程的名字(也就是 dbo.Products_Select).将其删除,替换为如下的SELECT statement,它返回某个 具体产品的所有列.

SELECT ProductID, ProductName, SupplierID, CategoryID,
    QuantityPerUnit, UnitPrice, UnitsInStock, UnitsOnOrder,
    ReorderLevel, Discontinued
FROM Products
WHERE ProductID = @ProductID

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图19:将存储过程的名字替换为一个SELECT查询.

接下来要对创 建的存储过程命名,输入Products_SelectByProductID,点Next.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图20:将新存储过程命名为Products_SelectByProductID

最后 一步将要我们对自动生成的名字重新命名,并指定是否使用Fill a DataTable模 式、是否使用Return a DataTable模式,抑或这2种模式都采用.就本文而言,都 选中这2项并将方法重命名为FillByProductID 和 GetProductByProductID.点 Next,再点Finish完成设置向导.

ASP.NET 2.0数据教程之六十七:在TableAdapters里创建新的存储过程

图21:将TableAdapter的方法重命名为Fill

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