繁体   English   中英

在transaction.Commit或Rollback之后连接对象会发生什么

[英]What happens to connection object after transaction.Commit or Rollback

我有一个名为Databaseprovider的类,我有一个名为CurrentTransaction的静态OracleTransaction属性。 以下是我为其分配值的方法:

        OracleConnection connection = ConnectionProvider.CreateConnection(conString);
        connection.Open();
        DatabaseProvider.CurrentTransaction = connection.BeginTransaction(IsolationLevel.ReadCommitted);

我刚刚注意到在Commit或Rollback之后,我的事务的连接属性被设置为null。 现在我想知道之前创建的OracleConnection对象会发生什么? 它是否会被关闭和处理,或者它成为一个免费的,无法访问的对象?

在代码具有.Close()之前,连接保持打开状态。

using block编写代码,而不是上面的代码。

using (OracleConnection connection = ConnectionProvider.CreateConnection(conString))
{
   ....
}

需要时初始化昂贵的物品,使用后将其丢弃。

使用try catch finally阻止并在finally块中显式关闭连接以释放连接。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM