Microsoft.Practices.EnterpriseLibrary.Data--使用存储过程,参数及事务

一. 使用存储过程:

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

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

 

 

1/** <summary>
2        /// 执行存储过程(1)——不传递参数(NoPara)
3        /// </summary>
4        private void FormatDataBySp1()
5        {
6            /**创建数据库实例
7            Database db = DatabaseFactory.CreateDatabase("NorthWind");
8           
9            /**传递参数
10            DbCommand dbc = db.GetStoredProcCommand("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            DbCommand dbc = db.GetStoredProcCommand("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            DbCommand dbc = db.GetStoredProcCommand("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        }

 

 

 

 

 

Microsoft.Practices.EnterpriseLibrary.Data 数据库操作

  1. Database db = null;  
  2.        
  3.       #region 一般调用  
  4.       db = DatabaseFactory.CreateDatabase("Connection String");  
  5.       int count = (int)db.ExecuteScalar(CommandType.Text, "SELECT Count(*) From cms_company");  
  6.       string message = string.Format("There are {0} customers in the database", count.ToString());  
  7.       Response.Write(message);  
  8.       #endregion  
  9.  
  10.  
  11.       #region 带返回参数,返回值和返回数据集,一般参数的存储过程  
  12.       //CREATE PROCEDURE [dbo].[kword]  
  13.       //@kword varchar(250)='',  
  14.       //@top int,  
  15.       //@otop varchar(250) output  
  16.       //As  
  17.       //select top 10 * from Table1 where ntitle like '%'+@kword+'%' and id>@top  
  18.       //declare @flag int  
  19.       //select @flag=100  
  20.       //SET @otop='返回值'  
  21.       //return @flag  
  22.       db = DatabaseFactory.CreateDatabase("serverConnectionString");//连接字符串变量名  
  23.       DbCommand dbcomm = db.GetStoredProcCommand("kword");//存储过程名  
  24.       db.AddInParameter(dbcomm, "@kword", DbType.String, "创业");//参数名 类型 值  
  25.       db.AddInParameter(dbcomm, "top", DbType.Int32, 2);//参数名 类型 值  
  26.       db.AddOutParameter(dbcomm, "otop", DbType.String, 250);//output参数名 类型 长度  
  27.       //关键在这里,添加一个参数@RETURN_VALUE 类型为ReturnValue  
  28.       db.AddParameter(dbcomm, "@RETURN_VALUE", DbType.String, ParameterDirection.ReturnValue, "", DataRowVersion.Current, null);  
  29.       DataSet ds = db.ExecuteDataSet(dbcomm);//必须有执行的动作后面才能获取值  
  30.       //title = (string)db.ExecuteScalar(dbcomm);如果返回只有一个数据,这样也是可以的  
  31.       GridView1.DataSource = ds;  
  32.       GridView1.DataBind();  
  33.   
  34.       Response.Write("<br>output输出参数值:" + db.GetParameterValue(dbcomm, "otop").ToString());  
  35.       // int testvalue = (int)dbcomm.Parameters["@RETURN_VALUE"].Value; //另一种获取值的方式  
  36.       Response.Write("<br />return返回参数值:" + db.GetParameterValue(dbcomm, "RETURN_VALUE").ToString());  
  37.       #endregion  
  38.  
  39.  
  40.  
  41.       #region 使用事务记录操作数据库  
  42.       //CREATE TABLE [dbo].[Table1](  
  43.       //    [id] [int] IDENTITY(1,1) NOT NULL,  
  44.       //    [ntitle] [varchar](250) NOT NULL,  
  45.       //    [valuea] [varchar](250) NULL,  
  46.       // CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED   
  47.       //(  
  48.       //    [ntitle] ASC  
  49.       //)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]  
  50.       //) ON [PRIMARY]  
  51.       db = DatabaseFactory.CreateDatabase("serverConnectionString");  
  52.       using (IDbConnection conn = db.CreateConnection())  
  53.       {  
  54.           conn.Open();  
  55.           IDbTransaction _trans = conn.BeginTransaction();  
  56.           try  
  57.           {  
  58.               DbCommand _cmd = db.GetSqlStringCommand("INSERT INTO [Table1]([ntitle],[valuea]) VALUES(@ntitle,@valuea)");  
  59.               db.AddInParameter(_cmd, "ntitle", DbType.String, "AA");  
  60.               db.AddInParameter(_cmd, "valuea", DbType.String, "AA");  
  61.               db.ExecuteNonQuery(_cmd, _trans as DbTransaction);  
  62.               db.ExecuteNonQuery(_cmd, _trans as DbTransaction);//ntitle字段上建有唯一索引,故第二次插入同样记录时会报错  
  63.               _trans.Commit();  
  64.           }  
  65.           catch  
  66.           {  
  67.               try  
  68.               {  
  69.                   _trans.Rollback();//事务提交失败时,则回滚(是否回滚成功,可查看表中有无AA的记录即可)  
  70.               }  
  71.               catch { }  
  72.           }  
  73.           finally  
  74.           {  
  75.               conn.Close();  
  76.           }  
  77.       }  
  78.       #endregion 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Microsoft.Practices.EnterpriseLibrary.Data是一个强大的.NET框架,用于开发企业级应用程序。连接字符串是用于连接到数据库的重要组成部分。在某些情况下,我们需要对连接字符串进行加密以增加安全性。 要对连接字符串进行加密,我们可以使用Microsoft提供的企业库(Enterprise Library)中的数据访问块(Data Access Block)。以下是一些步骤: 1. 首先,我们需要在项目中添加对Microsoft.Practices.EnterpriseLibrary.Data的引用。可以通过NuGet包管理器来安装。 2. 接下来,我们需要在config文件中定义连接字符串。可以使用app.config(用于Windows桌面应用程序)或web.config(用于Web应用程序)文件。例如: ``` <connectionStrings> <add name="MyDatabase" connectionString="[Your Connection String Here]" providerName="System.Data.SqlClient" /> </connectionStrings> ``` 3. 然后,我们需要在config文件中配置加密。可以在configSections中添加以下配置: ``` <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data" /> ``` 并在configuration节点下添加以下配置: ``` <dataConfiguration defaultDatabase="MyDatabase" /> ``` 4. 接下来,我们需要使用工具对连接字符串进行加密。可以使用命令行实用程序`encrypt.exe`,该程序位于Enterprise Library安装目录的bin文件夹中。 打开命令提示符,并导航到`encrypt.exe`所在的目录。然后使用以下命令对连接字符串进行加密: ``` encrypt.exe -section:connectionStrings -prov DataProtectionConfigurationProvider -appConfig "path\to\your\config\file" ``` 这将使用Windows数据保护API对连接字符串进行加密,并将结果存储在config文件中。 5. 最后,我们可以在代码中使用加密后的连接字符串。使用DatabaseFactory类的CreateDatabase方法来获取数据库实例。例如: ```csharp Database db = DatabaseFactory.CreateDatabase(); ``` 通过以上步骤,我们可以使用Microsoft.Practices.EnterpriseLibrary.Data的加密功能对连接字符串进行加密。这将增加我们应用程序的安全性,并保护敏感的数据库连接信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值