Welcome

首页 / 软件开发 / .NET编程技术 / Enterprise Library Step By Step系列(四)数据访问程序块 - 进阶篇

Enterprise Library Step By Step系列(四)数据访问程序块 - 进阶篇2011-01-28 cnblogs terrylee一.使用存储过程:

关于数据访问应用程序块的介绍在入门篇里面已经说过了,这里不再重复。下面我们来看看在数据访问应用程序块里面使用存储过程的方法:

1.不传递参数:不传递参数时值需要指定存储过程的名称,已经命令的类型即可。

1/**//// <summary>
2 /// 执行存储过程(1)——不传递参数(NoPara)
3 /// </summary>
4 private void FormatDataBySp1()
5 {
6 /**////创建数据库实例
7 Database db = DatabaseFactory.CreateDatabase("NorthWind");
8
9 /**////传递参数
10 DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("GetProductsList");
11
12 /**////执行存储过程
13 DataSet ds = db.ExecuteDataSet(dbc);
14
15 /**////绑定数据
16 DataGrid1.DataSource = ds.Tables[0];
17 DataGrid1.DataBind();
18 }

2.传递输入参数:需要注意的是在增加参数时是AddInParameter。

1/**//// <summary>
2 /// 执行存储过程(2)——传递输入参数(Input)
3 /// </summary>
4 private void FormatDataBySp2()
5 {
6 /**////创建数据库实例
7 Database db = DatabaseFactory.CreateDatabase("NorthWind");
8
9 /**////传递参数
10 DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("CustOrdersDetail");
11 dbc.AddInParameter("@OrderID",System.Data.DbType.Int32,10248);
12
13 /**////执行存储过程
14 DataSet ds = db.ExecuteDataSet(dbc);
15
16 /**////绑定数据
17 DataGrid1.DataSource = ds.Tables[0];
18 DataGrid1.DataBind();
19 }

3.传递输出参数:需要注意的是在增加参数时是AddOutParameter。

1/**//// <summary>
2 /// 执行存储过程(3)——传递输出参数(Output)
3 /// </summary>
4 private void FormatDataBySp3()
5 {
6 /**////创建数据库实例
7 Database db = DatabaseFactory.CreateDatabase("NorthWind");
8
9 /**////传递参数
10 DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("GetProductDetails");
11
12 dbc.AddInParameter("@ProductID",System.Data.DbType.Int32,12);
13 dbc.AddOutParameter("@ProductName",System.Data.DbType.String,50); //输出
14
15 /**////执行存储过程
16 db.ExecuteNonQuery(dbc);
17
18 string result = dbc.GetParameterValue("@ProductName").ToString(); //得到输出参数的值
19 }