使用存储过程,使用事务

原创 2007年09月17日 23:45:00

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

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

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        }
二.  使用事务:

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


 1/**//// <summary>
 2        /// 利用事务更改数据
 3        /// </summary>
 4        private void ExecuteUseTran()
 5        {
 6            /**////创建数据库实例
 7            Database db = DatabaseFactory.CreateDatabase("NorthWind");
 8
 9            using(IDbConnection Idbconn = db.GetConnection())
10            {    
11                /**////打开连接
12                Idbconn.Open();
13                
14                /**////创建事务
15                IDbTransaction Idbtran = Idbconn.BeginTransaction();
16
17                try
18                {    
19                    /**////执行两个存储过程
20                    db.ExecuteNonQuery(CommandType.StoredProcedure,"InserOrders");
21                    db.ExecuteDataSet(CommandType.StoredProcedure,"UpdateProducts");
22                    
23                    /**////执行完成后提交事务
24                    Idbtran.Commit();
25                }
26                catch
27                {    
28                    /**////回滚事务
29                    Idbtran.Rollback();
30                }
31                finally
32                {
33                    /**////关闭连接
34                    Idbconn.Close();
35                }
36            }
37
38        }
三.  加密连接字符串:

1.        创建一个加密的Stored Provider


按此在新窗口打开图片

2.        创建新的加密算法:


按此在新窗口打开图片


按此在新窗口打开图片

3.        选择加密算法:
按此在新窗口打开图片

4.        创建加密密钥:
按此在新窗口打开图片

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

按此在新窗口打开图片

6.        指定加密的部分:
按此在新窗口打开图片
这样我们看到,在配置文件里面的内容变成了乱码。


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

在mysql中的存储过程中使用事务transaction【以下内容仅供参考】

http://blog.sina.com.cn/s/blog_6dd65c6f0100t3u5.html 一. 在处理事务时,使用SQLException捕获SQL错误,然后处理; 按照这个推论,...
  • buster2014
  • buster2014
  • 2015年12月22日 22:04
  • 2012

SQLServer 存储过程中使用事务

存储过程SQL: create proc ***** @GoodsId int, @Number int, @StockPrice money, @SupplierId int, @EmpId in...
  • xie_xiansheng
  • xie_xiansheng
  • 2017年02月27日 15:29
  • 1409

sql server 存储过程,触发器,事务

尽管sql server 提供了使用方便的图形化用户界面,但是各种功能的实现基础是 transact-sql 语言. transact-sql语言直接来源于sql语言,因此也具有sql语言的几个...
  • yzr1183739890
  • yzr1183739890
  • 2015年12月13日 17:10
  • 2005

跨服务器操作插入表的存储过程使用了事务

  • 2013年05月22日 11:28
  • 2KB
  • 下载

EnterpriseLibrary 微软企业库 使用存储过程,参数及事务

一.  使用存储过程: 关于数据访问应用程序块的介绍在入门篇里面已经说过了,这里不再重复。下面我们来看看在数据访问应用程序块里面使用存储过程的方法: 1.        不传递参数:不传递...
  • xycit
  • xycit
  • 2013年12月13日 11:45
  • 3908

在MySql存储过程中使用事务

在MySql存储过程中使用事务现有如下的存储过程,执行插入操作。其中bill表中id为primary key,其它为字段为普通字段,没加任何索引与约束,多余的省略,不予展示。DROP PROCEDUR...
  • Revivedsun
  • Revivedsun
  • 2017年03月30日 00:50
  • 728

SQL SERVER中 存储过程使用事务与捕获异常

一、格式类似于 CREATE PROCEDURE YourProcedure AS BEGIN SET NOCOUNT ON; BEGIN TRY-------...
  • whaxrl
  • whaxrl
  • 2016年05月11日 22:03
  • 2160

Day 8(11.15):存储过程(5)--使用事务

-- 5 **************************************************** -- 使用事务 -- 事务是单个的工作单元。如果某一事务成功,则在该事务中进行的...
  • LuCh1Monster
  • LuCh1Monster
  • 2015年11月15日 16:53
  • 151

使用复制存储过程执行解决“事务复制中的表大量更新导致无法及时同步”的问题

来自:http://blog.csdn.net/zjcxc/article/details/8141844  复制存储过程执行应用于事务复制中,当在发布服务器上执行配置的存储过程时,存储过程...
  • ArvinStudy
  • ArvinStudy
  • 2012年11月29日 14:06
  • 450

SqlServer中视图、存储过程、事务的使用。

前言 正文 视图-VIEW VIEW介绍 VIEW使用 存储过程-SP 介绍 使用 事务-Transaction Transaction介绍 使用 Transaction种类 总结 如有错误请指教提前...
  • qq_34720759
  • qq_34720759
  • 2017年10月21日 13:38
  • 572
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用存储过程,使用事务
举报原因:
原因补充:

(最多只允许输入30个字)