Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇

时间:2021-04-29 08:47:10
Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇写在前面:在进阶篇中,主要通过对使用存储过程,使用事务,加密连接串三部分内容的介绍,给企业库的初学者提供一点帮助。 一.  使用存储过程:关于数据访问应用程序块的介绍在入门篇里面已经说过了,这里不再重复。下面我们来看看在数据访问应用程序块里面使用存储过程的方法:1.        不传递参数:不传递参数时值需要指定存储过程的名称,已经命令的类型即可。 1Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇/// <summary>
 2Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// 执行存储过程(1)――不传递参数(NoPara)
 3Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// </summary>

 4Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        private void FormatDataBySp1()
 5Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        {
 6Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///创建数据库实例
 7Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
 9Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///传递参数
10Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("GetProductsList");
11Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
12Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///执行存储过程
13Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataSet ds = db.ExecuteDataSet(dbc);
14Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
15Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///绑定数据
16Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataGrid1.DataSource = ds.Tables[0];
17Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataGrid1.DataBind();
18Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        }
2.        传递输入参数:需要注意的是在增加参数时是AddInParameter
 1Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇/// <summary>
 2Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// 执行存储过程(2)――传递输入参数(Input)
 3Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// </summary>

 4Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        private void FormatDataBySp2()
 5Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        {
 6Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///创建数据库实例
 7Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
 9Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///传递参数
10Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("CustOrdersDetail");
11Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            dbc.AddInParameter("@OrderID",System.Data.DbType.Int32,10248);
12Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
13Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///执行存储过程
14Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataSet ds = db.ExecuteDataSet(dbc);
15Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
16Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///绑定数据
17Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataGrid1.DataSource = ds.Tables[0];
18Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DataGrid1.DataBind();
19Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        }
3.        传递输出参数:需要注意的是在增加参数时是AddOutParameter
 1Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇/// <summary>
 2Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// 执行存储过程(3)――传递输出参数(Output)
 3Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// </summary>

 4Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        private void FormatDataBySp3()
 5Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        {
 6Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///创建数据库实例
 7Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
 9Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///传递参数
10Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("GetProductDetails");
11Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
12Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            dbc.AddInParameter("@ProductID",System.Data.DbType.Int32,12);
13Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            dbc.AddOutParameter("@ProductName",System.Data.DbType.String,50);    //输出
14Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
15Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///执行存储过程
16Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            db.ExecuteNonQuery(dbc);
17Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            
18Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            string result = dbc.GetParameterValue("@ProductName").ToString();    //得到输出参数的值
19Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        }
二.  使用事务:
在企业库数据访问应用程序块里面,对事务提供了很好的支持,具体的使用方法在程序里面有注释,这里就不多说了。
 1Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇/// <summary>
 2Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// 利用事务更改数据
 3Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        /// </summary>

 4Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        private void ExecuteUseTran()
 5Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        {
 6Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            ///创建数据库实例
 7Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
 9Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            using(IDbConnection Idbconn = db.GetConnection())
10Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            {    
11Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                ///打开连接
12Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                Idbconn.Open();
13Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                
14Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                ///创建事务
15Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                IDbTransaction Idbtran = Idbconn.BeginTransaction();
16Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
17Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                try
18Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                {    
19Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    ///执行两个存储过程
20Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    db.ExecuteNonQuery(CommandType.StoredProcedure,"InserOrders");
21Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    db.ExecuteDataSet(CommandType.StoredProcedure,"UpdateProducts");
22Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    
23Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    ///执行完成后提交事务
24Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    Idbtran.Commit();
25Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                }

26Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                catch
27Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                {    
28Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    ///回滚事务
29Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    Idbtran.Rollback();
30Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                }

31Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                finally
32Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                {
33Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    ///关闭连接
34Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                    Idbconn.Close();
35Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇                }

36Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇            }

37Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
38Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇        }
三.  加密连接字符串:
1.        创建一个加密的Stored ProviderEnterprise Library Step By Step系列(四):数据访问程序块――进阶篇2.        创建新的加密算法:Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇

Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
3.       
选择加密算法:
Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
4.       
创建加密密钥:


5.        保存加密密钥的保存文件,该文件要小心保存:
Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇6.        指定加密的部分: Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇
这样我们看到,在配置文件里面的内容变成了乱码。
总结:关于数据访问应用程序块的进阶篇就写到这里了,希望对初学企业库的朋友有所帮助Enterprise Library Step By Step系列(四):数据访问程序块――进阶篇

本文出自 “TerryLee技术专栏” 博客,请务必保留此出处http://terrylee.blog.51cto.com/342737/67602