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

  写在前面:在进阶篇中,主要通过对使用存储过程,使用事务,加密连接串三部分内容的介绍,给企业库的初学者提供一点帮助。

一.  使用存储过程:

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

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

 1 ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
 2InBlock.gif        /// 执行存储过程(1)——不传递参数(NoPara)
 3ExpandedBlockEnd.gif        /// </summary>

 4 None.gif          private   void  FormatDataBySp1()
 5 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 6ExpandedSubBlockStart.gifContractedSubBlock.gif            /**////创建数据库实例
 7InBlock.gif            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8InBlock.gif            
 9ExpandedSubBlockStart.gifContractedSubBlock.gif            /**////传递参数
10InBlock.gif            DBCommandWrapper dbc = db.GetStoredProcCommandWrapper("GetProductsList");
11InBlock.gif
12ExpandedSubBlockStart.gifContractedSubBlock.gif            /**////执行存储过程
13InBlock.gif            DataSet ds = db.ExecuteDataSet(dbc);
14InBlock.gif            
15ExpandedSubBlockStart.gifContractedSubBlock.gif            /**////绑定数据
16InBlock.gif            DataGrid1.DataSource = ds.Tables[0];
17InBlock.gif            DataGrid1.DataBind();
18ExpandedBlockEnd.gif        }

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

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

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

 1 ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
 2InBlock.gif        /// 执行存储过程(3)——传递输出参数(Output)
 3ExpandedBlockEnd.gif        /// </summary>

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

二.  使用事务:

在企业库数据访问应用程序块里面,对事务提供了很好的支持,具体的使用方法在程序里面有注释,这里就不多说了。

 1 ExpandedBlockStart.gif ContractedBlock.gif /**/ /// <summary>
 2InBlock.gif        /// 利用事务更改数据
 3ExpandedBlockEnd.gif        /// </summary>

 4 None.gif          private   void  ExecuteUseTran()
 5 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 6ExpandedSubBlockStart.gifContractedSubBlock.gif            /**////创建数据库实例
 7InBlock.gif            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8InBlock.gif
 9InBlock.gif            using(IDbConnection Idbconn = db.GetConnection())
10ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{    
11ExpandedSubBlockStart.gifContractedSubBlock.gif                /**////打开连接
12InBlock.gif                Idbconn.Open();
13InBlock.gif                
14ExpandedSubBlockStart.gifContractedSubBlock.gif                /**////创建事务
15InBlock.gif                IDbTransaction Idbtran = Idbconn.BeginTransaction();
16InBlock.gif
17InBlock.gif                try
18ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{    
19ExpandedSubBlockStart.gifContractedSubBlock.gif                    /**////执行两个存储过程
20InBlock.gif                    db.ExecuteNonQuery(CommandType.StoredProcedure,"InserOrders");
21InBlock.gif                    db.ExecuteDataSet(CommandType.StoredProcedure,"UpdateProducts");
22InBlock.gif                    
23ExpandedSubBlockStart.gifContractedSubBlock.gif                    /**////执行完成后提交事务
24InBlock.gif                    Idbtran.Commit();
25ExpandedSubBlockEnd.gif                }

26InBlock.gif                catch
27ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{    
28ExpandedSubBlockStart.gifContractedSubBlock.gif                    /**////回滚事务
29InBlock.gif                    Idbtran.Rollback();
30ExpandedSubBlockEnd.gif                }

31InBlock.gif                finally
32ExpandedSubBlockStart.gifContractedSubBlock.gif                dot.gif{
33ExpandedSubBlockStart.gifContractedSubBlock.gif                    /**////关闭连接
34InBlock.gif                    Idbconn.Close();
35ExpandedSubBlockEnd.gif                }

36ExpandedSubBlockEnd.gif            }

37InBlock.gif
38ExpandedBlockEnd.gif        }

三.  加密连接字符串:

1.        创建一个加密的Stored Provider

ED07.JPG

2.        创建新的加密算法:

ED08.JPG

ED09.JPG
3.        选择加密算法:

ED10.JPG
4.        创建加密密钥:
ED11.JPG

5.        保存加密密钥的保存文件,该文件要小心保存:
ED12.JPG

6.        指定加密的部分:

 ED13.JPG

这样我们看到,在配置文件里面的内容变成了乱码。

总结:关于数据访问应用程序块的进阶篇就写到这里了,希望对初学企业库的朋友有所帮助emsmile.gif

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值