Compartir a través de


Admitir transacciones en OLE DB

Actualización: noviembre 2007

Una transacción es una forma de agrupar, o de procesar por lotes, una serie de actualizaciones que se van a realizar en un origen de datos, de forma que todas tengan éxito y se confirmen de una vez, o (si se produce un error en una de ellas) no se confirme ninguna y se deshaga toda la transacción. Este proceso garantiza la integridad del resultado en el origen de datos.

OLE DB admite transacciones con los tres métodos siguientes:

Relación de sesiones y transacciones

Un único objeto de origen de datos puede crear uno o varios objetos de sesión, cada uno de los cuales puede hallarse dentro o fuera del ámbito de una transacción en un momento dado.

Cuando una sesión no entra en una transacción, todo el trabajo hecho en esa sesión en el almacén de datos queda confirmado inmediatamente en cada llamada de método. A veces se denomina modo de confirmación automática o modo implícito.

Cuando una sesión entra en una transacción, todo el trabajo realizado en esa sesión en el almacén de datos forma parte de la transacción y se confirma o anula como una unidad. A veces se denomina modo de confirmación manual.

La compatibilidad con transacciones es específica de cada proveedor. Si el proveedor que utiliza admite el uso de transacciones, un objeto de sesión que admita ITransaction e ITransactionLocal puede participar en una transacción simple (no anidada). La clase CSession de las plantillas OLE DB admite estas interfaces y es la forma recomendada para implementar la compatibilidad con transacciones en Visual C++.

Iniciar y finalizar la transacción

Se llama a los métodos StartTransaction, Commit y Abort en el objeto de conjunto de filas del consumidor.

Al llamar a ITransactionLocal::StartTransaction se inicia una nueva transacción local. Una vez iniciada, los cambios forzados por sucesivas operaciones no se aplican realmente al almacén de datos hasta que se confirme la transacción.

Al llamar a ITransaction::Commit o ITransaction::Abort se finaliza la transacción. Commit hace que todos los cambios incluidos en el ámbito de la transacción se apliquen al almacén de datos. Abort hace que se cancelen todos los cambios dentro del ámbito de la transacción y el almacén de datos quede en el estado que tenía antes de comenzar la transacción.

Transacciones anidadas

Una transacción anidada se produce al iniciar una nueva transacción local cuando ya existe una transacción activa en la sesión. La nueva transacción se inicia como una transacción anidada bajo la transacción actual. Si el proveedor no admite transacciones anidadas, al llamar a StartTransaction cuando ya hay una transacción activa en la sesión, se devuelve XACT_E_XTIONEXISTS.

Transacciones distribuidas

Una transacción distribuida es una transacción que actualiza datos distribuidos; es decir, datos repartidos en más de un equipo de una red. Si se desea admitir transacciones en un sistema distribuido, se debe utilizar .NET Framework en lugar de la compatibilidad con transacciones de OLE DB.

Para obtener más información acerca de las transacciones en Microsoft .NET Framework, vea Procesar transacciones en Kit de desarrollo de software de Windows (SDK).

Vea también

Conceptos

Utilizar descriptores de acceso