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

时间:2012-09-10 08:19:47

标签: c# oracle

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

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

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

2 个答案:

答案 0 :(得分:4)

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

使用using块编写代码,而不是上面的代码。

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

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

答案 1 :(得分:2)

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