Compartir a través de


Método Workspace.CommitTrans (DAO)

Se aplica a: Access 2013, Office 2013

Termina la transacción actual y guarda los cambios.

Sintaxis

expresión . CommitTrans(Options)

expression Variable que representa un objeto Workspace.

Parameters

Nombre

Obligatorio/opcional

Tipo de datos

Descripción

Opción

Opcional

Long

En un área de trabajo de Microsoft Access, puede incluir la constante dbForceOSFlush con CommitTrans. Esto fuerza al motor de base de datos a guardar de inmediato todas las actualizaciones en el disco, en lugar de guardarlas en la caché temporalmente. Si no utiliza esta opción, un usuario podría recuperar el control de inmediato después de que el programa de aplicación llame a CommitTrans, apagar el equipo y no haber escrito los datos en el disco. Aunque el uso de esta opción puede afectar al rendimiento de la aplicación, es útil en situaciones en las que el equipo puede apagarse antes de guardar en el disco las actualizaciones de la memoria caché.

Comentarios

Los métodos de transacción BeginTrans, CommitTrans y Rollback administran el procesamiento de transacciones durante una sesión definida por un objeto Workspace. Estos métodos se utilizan con un objeto Workspace cuando se desea tratar un conjunto de cambios realizados en las bases de datos en una sesión como una sola unidad.

Normalmente, se utilizan transacciones para mantener la integridad de los datos cuando es necesario actualizar registros en dos o más tablas y, al mismo tiempo, asegurarse de que los cambios se realizan (se validan) en todas las tablas o en ninguna (se revierten). Por ejemplo, si transfiere dinero de una cuenta a otra, podría restar una cantidad de una cuenta y agregar dicha cantidad a la otra cuenta. Si alguna de las actualizaciones no se realiza correctamente, las cuentas no cuadrarán. Utilice el método BeginTrans antes de actualizar el primer registro y, a continuación, si la siguiente actualización produce un error, puede utilizar el método Rollback para deshacer todas las actualizaciones. Use el método CommitTrans una vez actualizado correctamente el último registro.

Nota:

[!NOTA] Dentro de un objeto Workspace, las transacciones son siempre globales con respecto al Workspace y no se limitan a un único objeto Connection o Database. Si realiza operaciones en varias conexiones o bases de datos dentro de una transacción de Workspace, la resolución de las transacciones (por ejemplo, mediante el método CommitTrans o Rollback) afecta a todas las operaciones en todas las conexiones y bases de datos dentro de esa área de trabajo.

Después de utilizar CommitTrans, no se pueden deshacer los cambios realizados a no ser que la transacción esté anidada dentro de otra transacción que haya sido revertida. Si anida transacciones, debe resolver la transacción actual antes de resolver una transacción situada en un nivel de anidamiento superior.

Si desea realizar transacciones simultáneas con ámbitos superpuestos no anidados, puede crear objetos Workspace adicionales que contengan las transacciones simultáneas.

Si cierra un objeto Workspace sin resolver las transacciones pendientes, las transacciones se revierten automáticamente.

Si utiliza el método CommitTrans o Rollback sin usar primero el método BeginTrans, se produce un error.

Es posible que algunas bases de datos ISAM usadas en un área de trabajo de Microsoft Access no admitan transacciones, en cuyo caso la propiedad Transactions del objeto Database o del objeto Recordset es False. Para asegurarse de que la base de datos admite transacciones, compruebe el valor de la propiedad Transactions del objeto Database antes de usar el método BeginTrans. Si usa un objeto Recordset basado en varias bases de datos, compruebe la propiedad Transactions del objeto Recordset.

Si un objeto Recordset se basa íntegramente en tablas del motor de base de datos de Microsoft Access, siempre puede usar transacciones. No obstante, es posible que los objetos Recordset basados en tablas creadas por otros productos de base de datos no admitan transacciones. Por ejemplo, no puede usar transacciones en un objeto Recordset basado en una tabla de Paradox. En este caso, la propiedad Transactions es False. Si los objetos Database o Recordset no admiten transacciones, los métodos se omiten y no se produce ningún error.

No puede anidar transacciones si tiene acceso a orígenes de datos de ODBC a través del motor de base de datos de Microsoft Access.

En áreas de trabajo de ODBC, cuando usa CommitTrans, es posible que el cursor ya no sea válido. Use el método Requery para ver los cambios en Recordset, o bien cierre y vuelva a abrir Recordset.

Nota:

  • A menudo, es posible aumentar el rendimiento de la aplicación dividiendo las transacciones que requieren acceso al disco en bloques de transacciones. De esta forma, las operaciones se almacenan en un búfer y se reduce considerablemente el número de operaciones de acceso al disco.
  • En un área de trabajo de Microsoft Access, las transacciones se registran en un archivo almacenado en el directorio especificado por la variable de entorno TEMP en la estación de trabajo. Si el archivo de registro de transacciones utiliza todo el espacio de almacenamiento disponible en la unidad TEMP, el motor de base de datos genera un error en tiempo de ejecución. En este punto, si utiliza CommitTrans, se validan un número indeterminado de transacciones, pero las operaciones incompletas restantes se pierden y es necesario reiniciar la operación. Al utilizar el método Rollback, se libera el registro de transacciones y se revierten todas las operaciones de la transacción.
  • Al cerrar una copia del objeto Recordset en una transacción pendiente, se genera una operación Rollback implícita.

Ejemplo

En el ejemplo siguiente, se muestra cómo usar una transacción en un área de trabajo de objetos de acceso a datos (DAO).

Código de ejemplo proporcionado por la Referencia del programador de Microsoft Access 2010.

    Public Sub TransferFunds()
        Dim wrk As DAO.Workspace
        Dim dbC As DAO.Database
        Dim dbX As DAO.Database
        
        Set wrk = DBEngine(0)
        Set dbC = CurrentDb
        Set dbX = wrk.OpenDatabase("e:\books\acc2007vba\myDB.accdb")
        
        On Error GoTo trans_Err
        
        'Begin the transaction
        
        wrk.BeginTrans
        
        'Withdraw funds from one account table
        dbC.Execute "INSERT INTO tblAccounts ( Amount, Txn, TxnDate ) SELECT -20, 'DEBIT', Date()", dbFailOnError
    
        'Deposit funds into another account table
        dbX.Execute "INSERT INTO tblAccounts ( Amount, Txn, TxnDate ) SELECT 20, 'CREDIT', Date()", dbFailOnError
        
        'Commit the transaction
        wrk.CommitTrans dbForceOSFlush
        
    trans_Exit:
        'Clean up
        wrk.Close
        Set dbC = Nothing
        Set dbX = Nothing
        Set wrk = Nothing
        Exit Sub
        
    trans_Err:
        'Roll back the transaction
        wrk.Rollback
        Resume trans_Exit
        
    End Sub