1

我正在使用 DbProviderFactories 提供的通用 DbConnection 访问数据库,并且我观察到在使用连接之前我不需要调用 Open 。我提供了一个有效的示例代码(使用“System.Data.SqlClient”或“Oracle.DataAccess.Client”作为 providerInvariantName 参数)。我已经使用类似的代码执行了所有 CRUD 操作,而没有在连接上显式调用 Open,没有任何明显的错误。

我知道我不需要关闭它,因为 using 语句负责关闭和处理连接。但是,什么时候在这段代码中打开连接呢?当我在关联的 DataAdapter 上调用 Fill 时,它会自动打开吗?在使用连接对象之前未在连接对象上显式调用 Open 是否有任何后果?因为如果它是不必要的,我可以为自己节省几行代码,我肯定会这样做。;-)

DbProviderFactory myFactoryProvider = DbProviderFactories.GetFactory("System.Data.SqlClient");// same with "Oracle.DataAccess.Client"
using (var myConnection = myFactoryProvider.CreateConnection())
using (var myCommand = myFactoryProvider.CreateCommand())
{
    try
    {       
        // Set up the connection                  
        myConnection.ConnectionString = _someConnectionString;
        myCommand.Connection = myConnection;
        myCommand.CommandText = "SELECT * FROM SOME_TABLE";     

        // Create DataAdapter and fill DataTable                    
        DbDataAdapter dataAdapter = myFactoryProvider.CreateDataAdapter();
        dataAdapter.SelectCommand = myCommand;
        DataTable myTable = new DataTable();
        dataAdapter.Fill(myTable);
        // Read the table and do something with the data
        foreach (DataRow fila in myTable.Rows)
        {
            // Do  something
        }                          
    }
    catch (Exception e)
    {
        string message = e.ToString();
        throw;
    }
} //using closes and disposes the connection and the command
4

1 回答 1

0

语句时应建立并打开与数据库的连接

dataAdapter.Fill(myTable);

运行,所以你的代码运行良好

于 2016-06-15T08:33:06.043 回答