Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Ciclo FOR
declare
cursor public cur is
select col1, col2
from tabla;
begin
for v_reg in cur loop
dbms_output.put_line ('Col1: '|| v_reg.col1 ||'
v_reg.col2);
end loop;
end;
Col2: '||
La variable v_reg se declara automticamente y tiene validez nicamente dentro del ciclo
FOR.
Es posible definir argumentos al declarar un cursor:
declare
cursor cur (p_col3 col3%type) is
select col1, col2
from tabla
where col3 = p_col3;
v_col3 tabla.col3%type;
begin
v_col3 := 7;
Col2: '||
Col2: '||
REF CURSOR
Tambin se pueden definir cursores variables, a diferencia de los estticos utilizados hasta
ahora:
declare
type t_cursor is ref cursor return tabla%rowtype;
v_cursor t_cursor;
v_reg tabla%rowtype;
begin
open v_cursor for
select col1, col2
from tabla;
loop
fetch v_cursor into v_reg;
exit when v_cursor%notfound;
dbms_output.put_line ('Col1: '|| v_reg.col1 ||'
v_reg.col2);
end loop;
close v_cursor;
end;
Col2: '||
Los cursores variables pueden ser pasados como parmetros en procedimientos y funciones.
Tambin es posible no especificar el tipo de registro retornado por el cursor, lo cual permite
mayor flexiblidad pero impide verificar los tipos en tiempo de compilacin, lo cual puede
dar lugar a errores imprevistos en tiempo de ejecucin.
Cursores de actualizacin
Declaracin y utiizacin de cursores de actualizacin.
Los cursores de actualizacin se declarn igual que los cursores explicitos, aadieno
FOR UPDATE al final de la sentencia select.
CURSOR nombre_cursor IS
instruccin_SELECT
FOR UPDATE
Para actualizar los datos del cursor hay que ejecutar una sentencia UPDATE
especificando la clausula WHERE CURRENT OF <cursor_name>.
UPDATE <nombre_tabla> SET
<campo_1> = <valor_1>
[,<campo_2> = <valor_2>]
WHERE CURRENT OF <cursor_name>
COMMIT;
END;
Excepciones en PL/SQL
Manejo de excepciones
En PL/SQL una advertencia o condicin de error es llamada una excepcin.
Las excepciones se controlan dentro de su propio bloque.La estructura de bloque de una
excepcin se muestra a continuacin.
DECLARE
-- Declaraciones
BEGIN
-- Ejecucion
EXCEPTION
-- Excepcion
END;
CURSOR_ALREADY_OPEN
Se ejecuta ...
SQLCODE
VALUE_ERROR
ZERO_DIVIDE
ms de una fila
Ocurri un error aritmtico, de
conversin o truncamiento. Por ejemplo,
sucede cuando se intenta calzar un valor -6502
muy grande dentro de una variable ms
pequea
El programa intent efectuar una
-1476
divisin por cero
DECLARE
-- Declaraciones
MyExcepcion EXCEPTION;
BEGIN
-- Ejecucion
EXCEPTION
-- Excepcion
END;
Reglas de Alcance
Una excepcion es vlida dentro de su ambito de alcance, es decir el bloque o programa
donde ha sido declarada. Las excepciones predefinidas son siempre vlidas.
Como las variables, una excepcin declarada en un bloque es local a ese bloque y global
a todos los sub-bloques que comprende.
La sentencia RAISE
La sentencia RAISE permite lanzar una excepcin en forma explcita. Es posible utilizar
esta sentencia en cualquier lugar que se encuentre dentro del alcance de la excepcin.
DECLARE
EXCEPTION
-- Excepcion
WHEN VALOR_NEGATIVO THEN
dbms_output.put_line('El valor no puede ser negativo');
END;
Con la sentencia RAISE podemos lanzar una excepcin definida por el usuario o
predefinida, siendo el comportamiento habitual lanzar excepciones definidas por el usuario.
Recordar la existencia de la excepcin OTHERS, que simboliza cualquier condicin de
excepcin que no ha sido declarada. Se utiliza comnmente para controlar cualquier tipo de
error que no ha sido previsto. En ese caso, es comn observar la sentencia ROLLBACK en
el grupo de sentencias de la excepcin o alguna de las funciones SQLCODE
SQLERRM, que se detallan en el prximo punto.
Uso de SQLCODE y SQLERRM
Al manejar una excepcin es posible usar las funciones predefinidas SQLCode y
SQLERRM para aclarar al usuario la situacin de error acontecida.
SQLcode devuelve el nmero del error de Oracle y un 0 (cero) en caso de exito al
ejecutarse una sentencia SQL.
Por otra parte, SQLERRM devuelve el correspondiente mensaje de error.
Estas funciones son muy tiles cuando se utilizan en el bloque de excepciones, para
aclarar el significado de la excepcin OTHERS.
Estas funciones no pueden ser utilizadas directamente en una sentencia SQL, pero s se
puede asignar su valor a alguna variable de programa y luego usar esta ltima en alguna
sentencia.
DECLARE
err_num NUMBER;
err_msg VARCHAR2(255);
result NUMBER;
BEGIN
SELECT 1/0 INTO result
FROM DUAL;
EXCEPTION
WHEN OTHERS THEN
err_num := SQLCODE;
err_msg := SQLERRM;
DBMS_OUTPUT.put_line('Error:'||TO_CHAR(err_num));
DBMS_OUTPUT.put_line(err_msg);
END;
Tambin es posible entregarle a la funcin SQLERRM un nmero negativo que represente un error de
Oracle y sta devolver el mensaje asociado.
DECLARE
msg VARCHAR2(255);
BEGIN
msg := SQLERRM(-1403);
DBMS_OUTPUT.put_line(MSG);
END;