Diferència entre revisions de la pàgina «P8-Gestió d'excepcions»

De wikiserver
Dreceres ràpides: navegació, cerca
Línia 27: Línia 27:
 
ejecutado correctamente. La salida es la siguiente:
 
ejecutado correctamente. La salida es la siguiente:
  
[[Fitxer:8-1.png|500px|casos]]
+
[[Fitxer:8-1.png|250px|resultat]]
 +
 
 
8) Cambie el valor inicializado de v_emp_sal a 2000 y vuelva a ejecutar. La salida es
 
8) Cambie el valor inicializado de v_emp_sal a 2000 y vuelva a ejecutar. La salida es
 
la siguiente:
 
la siguiente:
[[Fitxer:8-2.png|500px|casos]]
+
 
2) Manejo de Excepciones de Oracle Server Estándar
+
[[Fitxer:8-2.png|250px|sortida]]
 +
 
  
 
== 2) Manejo de Excepciones de Oracle Server Estándar ==
 
== 2) Manejo de Excepciones de Oracle Server Estándar ==

Revisió del 17:32, 1 des 2014

1) Manejo de Excepciones Predefinidas

 En esta práctica escribirá un bloque PL/SQL que aplique una excepción predefinida para
 procesar un único registro a la vez. El bloque PL/SQL seleccionará el nombre del
 empleado con un valor de salario determinado.

1) Ejecute el comando en el archivo lab_05_01.sql para volver a crear la tabla messages.

2) En la sección de declaraciones, declare dos variables: v_ename del tipo employees.last_name y v_emp_sal del tipo employees.salary. Inicialice la última en 6000.

3) En la sección ejecutable, recupere los apellidos de los empleados cuyos salarios son iguales al valor de v_emp_sal. Si el salario introducido devuelve sólo una fila, inserte en la tabla messages el nombre y el importe del salario del empleado. Nota: no utilice cursores explícitos.

4) Si el salario introducido no devuelve ninguna fila, maneje la excepción con un manejador de excepciones adecuado e inserte en la tabla messages el mensaje “No employee with a salary of <salary>”.

5) Si el salario introducido devuelve varias filas, maneje la excepción con un manejador de excepciones adecuado e inserte en la tabla messages el mensaje “More than one employee with a salary of <salary>”.

6) Maneje cualquier otra excepción con un manejador de excepciones adecuado e inserte en la tabla messages el mensaje “Some other error occurred”.

7) Muestre las filas de la tabla messages para comprobar si el bloque PL/SQL se ha ejecutado correctamente. La salida es la siguiente:

resultat

8) Cambie el valor inicializado de v_emp_sal a 2000 y vuelva a ejecutar. La salida es la siguiente:

sortida


2) Manejo de Excepciones de Oracle Server Estándar

 En esta práctica, escribirá un bloque PL/SQL que declare una excepción para el error de
 Oracle Server ORA-02292 (integrity constraint violated – child
 record found). El bloque comprobará la excepción y mostrará el mensaje de error.

1) En la sección de declaraciones, declare una excepción e_childrecord_exists. Asocie la excepción declarada al error de Oracle Server estándar –02292.

2) En la sección ejecutable, muestre “Deleting department 40....” Incluya una sentencia DELETE para suprimir el departamento con department_id 40.

3) Incluya una sección de excepciones para manejar la excepción e_childrecord_exists y muestre el mensaje adecuado. La salida de ejemplo es la siguiente: