FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
savepoint en oracle
alguien ha usado un savepoint (PL/SQL), me puede explicar mas al respecto???.
Gracias..
__________________
J4CO |
#2
|
||||
|
||||
La idea de los SavePoints es manejar por pasos las transacciones, pudiendo hacer rollbacks hasta un punto marcado por el savepoint y no por toda la sesión.
Código:
INSERT INTO ...; SAVEPOINT A; UPDATE ....; SAVEPOINT B; INSERT INTO ...; SAVEPOINT C; IF .... THEN ROLLBACK TO B; ELSE COMMIT; END; Saludos!
__________________
delphi.com.ar Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla. |
#3
|
|||
|
|||
pero por ejemplo en la sentencia IF....THEN como podria preguntar que las ordenes Sql anteriores se hallan ejecutado bien???..
Gracias
__________________
J4CO |
#4
|
||||
|
||||
Cuando una consulta no se ejecuta bien, esta produce un error. Para eso te recomiendo investigar la captura de errores de PLSQL, es muy parecida a ADA.
Básicamente cada bloque (begin..end), puede capturar errores.. Ej: [code] FUNCTION GET_ALGO(AId IN NUMBER) RETURN NUMBER AS nResult NUMBER; BEGIN SELECT ... INTO nResult FROM TABLA WHERE ID = AId; RETURN nResult; EXCEPTION WHEN NO_DATA_FOUND THEN RETURN 0; WHEN OTHERS THEN RETURN -1; END; Y se podrían anidar bloques dentro de este, con sus respectivas capturas de errores. Saludos!
__________________
delphi.com.ar Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla. |
#5
|
|||
|
|||
existe alguna dirección donde salga algun ejemplo mas concreto respecto a los Savepoint.... donde pueda sacar la manera de implementarlo??, he leido bastante pero no se como implementarlo en un caso practico..
Gracias de antemano..
__________________
J4CO |
#6
|
||||
|
||||
Te digo que prácticamente en los últimos 5 años no los he usado nunca... recuerdos haberlos usado en la época del sqlplus, cuando uno iba probando algo y si fallaba quería deshacer los cambios hasta tal punto... Pero dentro de un procedure, evito utilizar transacciones, a no ser que sea un proceso muy grande.
Si deseas buscar ejemplos, en oracle.com no deben faltar. Saludos!
__________________
delphi.com.ar Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla. |
#7
|
|||
|
|||
con eso me queda claro..
Gracias..
__________________
J4CO |
|
|
|