InicioArticulos y noticiasBases de datosProgramaciónForosInternetServiciosContratacionEmail
Tutorial PL/SQL
Introducción a PLSQL
Programación con PL/SQL
Fundamentos de PL/SQL
Tipos de datos en PL/SQL
Operadores en PL/SQL
Estructuras de control en PL/SQL
Bloques PL/SQL
Cursores en PL/SQL
Cursores Implicitos en PL/SQL
Cursores Explicitos en PL/SQL
Cursores de actualización en PL/SQL
Excepciones en PL/SQL
Excepciones personalizadas en PL/SQL
Propagacion de excepciones en PL/SQL
Subprogramas en PL/SQL
Procedimientos almacenados en PL/SQL
Funciones en PL/SQL
Triggers en PL/SQL
Subprogramas en bloques anónimos
Paquetes en PL/SQL
Registros PL/SQL
Tablas PL/SQL
Tipo VARRAY
BULK COLLECT
Transacciones con PL/SQL
Transacciones autónomas
SQL Dinamico
Funciones integradas de PL/SQL
Secuencias
PL/SQL y Java
También puedes ver ...
Excepciones personalizadas en PL/SQL
Como conectar a ORACLE con Java
Recuperar datos BLOB de ORACLE
Trabajar con datos de tipo BLOB en ORACLE
PL/SQL y Java
Secuencias
Transacciones autónomas
SQL Dinamico
Funciones integradas de PL/SQL
Tipo VARRAY


Transacciones

    Una transacción es un conjunto de operaciones que se ejecutan en una base de datos, y que son tratadas como una única unidad lógica por el SGBD.

    Es decir, una transacción es una o varias sentencias SQL que se ejecutan en una base de datos como una única operación, confirmandose o deshaciendose en grupo.

    No todas las operaciones SQL son transaccionales. Sólo son transaccionales las operaciones correspondiente al DML, es decir, sentencias SELECT, INSERT, UPDATE y DELETE

    Para confirmar una transacción se utiliza la sentencia COMMIT. Cuando realizamos COMMIT los cambios se escriben en la base de datos.

    Para deshacer una transacción se utiliza la sentencia ROLLBACK. Cuando realizamos ROLLBACK se deshacen todas las modificaciones realizadas por la transacción en la base de datos, quedando la base de datos en el mismo estado que antes de iniciarse la transacción.

    Un ejemplo clásico de transacción son las transferencias bancarias. Para realizar una transferencia de dinero entre dos cuentas bancarias debemos descontar el dinero de una cuenta, realizar el ingreso en la otra cuenta y grabar las operaciones y movimientos necesarios, actuaizar los saldos ... .Si en alguno de estos puntos se produce un fallo en el sistema podríamos hacer descontado el dinero de una de las cuentas y no haberlo ingresado en la otra. Por lo tanto, todas estas operaciones deben ser correctas o fallar todas. En estos casos, al confirmar la transaccion (COMMIT) o al deshacerla (ROLLBACK) garantizamos que todos los datos quedan en un estado consistente.

    En una transacción los datos modificados no son visibles por el resto de usuarios hasta que se confirme la transacción.

    El siguiente ejemplo muestra una supuesta transacción bancaria:


DECLARE
  
importe NUMBER;
   ctaOrigen VARCHAR2(23);
   ctaDestino VARCHAR2(23);
BEGIN
     importe := 100;
     ctaOrigen  := '2530 10 2000 1234567890';
     ctaDestino := '2532 10 2010 0987654321';
     UPDATE CUENTAS SET SALDO = SALDO - importe
     WHERE CUENTA = ctaOrigen;
     UPDATE CUENTAS SET SALDO = SALDO + importe
     WHERE CUENTA = ctaDestino;
     INSERT INTO MOVIMIENTOS
     (CUENTA_ORIGEN, CUENTA_DESTINO,IMPORTE, FECHA_MOVIMIENTO)
     VALUES
     (ctaOrigen, ctaDestino, importe*(-1), SYSDATE);
     INSERT INTO MOVIMIENTOS
     (CUENTA_ORIGEN, CUENTA_DESTINO,IMPORTE, FECHA_MOVIMIENTO)
     VALUES
     (ctaDestino,ctaOrigen, importe, SYSDATE);
     COMMIT;
EXCEPTION
WHEN OTHERS THEN
     dbms_output.put_line('Error en la transaccion:'||SQLERRM);
     dbms_output.put_line('Se deshacen las modificaciones);
     ROLLBACK;
END;

    Si alguna de las tablas afectadas por la transacción tiene triggers, las operaciones que realiza el trigger están dentro del ambito de la transacción, y son confirmadas o deshechas conjuntamente con la transacción.

    Durante la ejecución de una transacción, una segunda transacción no podrá ver los cambios realizados por la primera transacción hasta que esta se confirme.

    ORACLE es completamente transaccional. Siempre debemos especificar si que queremos deshacer o confirmar la transacion.

 


Inicio | Tutorial PL/SQL BULK COLLECTTutorial PL/SQLTransacciones autónomas Versión para imprimir Foros de consulta

 
duda por juan
Respuesta recibida el [04/04/2008 01:11:38]
"Durante la ejecución de una transacción, una segunda transacción no podrá ver los cambios realizados por la primera transacción hasta que esta se confirme."
Exactamente que quiere decir?gracias
PD:enhorabuena por el tutorial

 
respuesta a duda por uno
Respuesta recibida el [29/04/2008 05:14:10]
yo entendi que:
imagina que una transaccion es una secuencia de updates y que en un momento hay un fallo y se han de deshacer los canvios, si una segunda transaccion estaba accediendo a los mismos datos y la primera transaccion los deshace justo despues por el rollback, la segunda transaccion tendra valores incorrectos.
Si se espera al commit o rollback,tendran los mismos valores.

 
otra respuesta por Arturo Pinochet
Respuesta recibida el [06/05/2008 12:00:58]
Creo que era mas bien, por ejemplo, si la primera transaccion comienza en el tiempo 1 y termina en el 10, y la segunda comienza en el tiempo 5 y termina en el 15, la segunda transaccion verá los valores originales, puesto que la primera todavia no los ha modificado (no ha hecho commit)

 
clara explicación por Roy
Respuesta recibida el [29/07/2008 04:15:19]
Muy clara la explicación, hacen ver este tema sencillo

 
si la transaccion involucra varios PLs por villa
Respuesta recibida el [15/10/2008 05:30:40]
que pasa si la transaccion involucra varios procedimientos pl/sql.¿hago commit o rollback en el ultimo?...me podrian ayudar

 
Nunca participo en foros pero ... por Luc
Respuesta recibida el [07/07/2009 06:32:03]
Nunca participo en foros pero voy hacer una excepción para felicitarte por tan buen tutorial, de lo más didáctico que se encuentra en la red. 

 
Transaccion con un padre y varios hijos como seria este ejemplo por Jorge
Respuesta recibida el [23/07/2009 11:25:41]
Dadas 2 tablas

Tabla A: IdPadre,Padre
Tabla B: IdHijo,Hijo,IdPadre(FK)

Necesito hacer un procedimiento almacenado q inserte el padre siempre q inserte todos los hijos (Cada padre puede tener 0,1 o mas hijos)
Y si falla el insert de algun hijo q realice el Rollback tanto del padre como los hijos insertados.
Como seria el procedimiento almacenado?


Añadir comentario ... Para preguntar utiliza los foros
Autor:

Título:


Para preguntar utiliza los foros.



Inicio | Tutorial PL/SQL BULK COLLECTTutorial PL/SQLTransacciones autónomas Versión para imprimir

Transacciones con PL/SQL
Autor: Pedro Herrarte Sánchez
Visitas: 38529 Fecha de publicación: 20/07/2006
Pedro Herrarte, es consultor independiente, ofreciendo servicios de consultoría, análisis, desarrollo y formación.

Posee mas de diez años de experiencia trabajando para las principales empresas de España.

Es especialista en tecnologías .NET, entornos Web, bases de datos (SQL Server y ORACLE) e integración de sistemas.

Es experto en desarrollo (C#, ASP.NET, VB.Net, T-SQL, PL/SQL, , ASP, CGI , C, Pro*C, Java, Essbase, Vignette, PowerBuilder y Visual Basic ...) y bases de datos (SQL Server y ORACLE).

Es fundador, diseñador y programador de www.devjoker.com.




Visitas: 109 | Comentarios: 3 | Archivo: Articulos
02/02/2010 iPad vs Telesketch
Visitas: 809 | Comentarios: 2 | Archivo: Articulos
Categorias: Humor
Visitas: 764 | Comentarios: 3 | Archivo: Articulos
Visitas: 3177 | Comentarios: 2 | Archivo: Articulos
Categorias: C#
Visitas: 14561 | Comentarios: 7 | Archivo: Articulos
Categorias: C#|Seguridad
Visitas: 1497 | Comentarios: 3 | Archivo: Articulos
Visitas: 695 | Comentarios: 2 | Archivo: Articulos
Visitas: 369 | Comentarios: 0 | Archivo: Articulos
Visitas: 2034 | Comentarios: 2 | Archivo: Articulos
Categorias: C#

Útimos temas recibidos en los foros ...
certificado por jhon jairo vargas ... [Actualidad] 1 13/03/2010
devolver consulta en form builder de oracle con like por cesar10lb ... [ORACLE] 0 13/03/2010
certificado de cesantias horizonte por yeimmy ... [Actualidad] 4 13/03/2010
solicito certificado de pensiones y sesantias para laborar por maria eugenia garcia m. ... [Actualidad] 0 13/03/2010
certificado de fondos de pensiones horizonte por mona ... [Actualidad] 6 03/03/2010
certificado pensiones por nelly moreno ... [Actualidad] 0 13/03/2010
certificado de pensiones del bbva horizonte por danger ... [Actualidad] 125 12/01/2010
cerificado fondo horizonte de pensiones y cesantias por carlos fideligno torres herrera ... [Actualidad] 147 18/01/2010
certuficado de afiliacion a porvenir por ede ... [Actualidad] 6 05/02/2010
certificado pensiones horizonte por angela patricia rodriguez ... [Actualidad] 136 26/01/2010
Solicitud certificado de afiliaciones a pensiones y cesantias proteccion por hz ... [Actualidad] 59 10/02/2010
necesito certificado de afiliacíon a pensiones por jelo ... [Actualidad] 0 12/03/2010

Access CGI JSP ORACLE UNIX
Actualidad HTML/DHTML/XHTML LINUX PHP Visual Basic .NET
ASP ISAPI MS DOS Power Builder Visual Basic 6.0
ASP.NET Java mySQL SQL WIN 98/NT/2000/XP
C# JavaScript Opinion SQL Server

devjoker  Te recomendamos además ...
15/07/2007 Consultas agregadas    forma parte de...Tutorial de Transact SQL
06/07/2007 Select FOR XML    forma parte de...Tutorial de Transact SQL
11/10/2006 Métodos    forma parte de...Tutorial C#
11/10/2006 Orden de inicialización de variables    forma parte de...Tutorial C#
11/10/2006 Constantes    forma parte de...Tutorial C#
09/05/2006 Como leer XML con C#
09/10/2006 Cadenas de texto    forma parte de...Tutorial C#
22/10/2005 Actualización de datos. UPDATE    forma parte de...Tutorial SQL
11/03/2008 Problemas en la instalación de Visual Studio 2008-Visual studio web authoring component
19/08/2006 Virtualización. Maquinas Virtuales.

 

Encuesta
¿A que perfil te adaptas mejor?




[Ver] [Votar]