S UBPROGRAMAS PL/SQL © César Martínez C. Profesor Instructor de Base de Datos Sede Puente Alto DUOC I NTRODUCCIÓN Los subprogramas son otro tipo de bloques PL/SQL Se diferencian de los bloques anónimos porque llevan nombre, se almacenan en la base de datos y algunos pueden usar parámetros Los subprogramas que estudiaremos son: Procedimientos Almacenados Funciones Triggers P ROCEDIMIENTOS A LMACENADOS Los procedimientos almacenados son utilizados para que realicen cierta operatoria pero que no devuelven resultados al que invocó dicho procedimiento Sintaxis: Create [or Replace] Procedure «nombre_proc» [(lista_parametros)] is ….. End [«nombre_proc»]; C ONSIDERACIONES PARA P ROCEDIMIENTOS A LMACENADOS Al ocupar «Or Replace», en el caso que el procedimiento almacenado ya se encuentre en la BD, éste se reemplazará. En caso contrario, arrojará un error en la compilación No es obligatorio agregar el nombre del procedimiento al finalizar su código Un procedimiento almacenado posee las mismas secciones que un bloque anónimo (declaraciones, ejecución y excepciones). La diferencia es que la declaración «Create…Is» reemplaza a «Declare» Para eliminar un procedimiento almacenado se usa: Drop procedure «nombre_procedimiento»; E JEMPLO DE P ROCEDIMIENTO A LMACENADO Procedimiento Declarado E JECUTAR EL P ROCEDIMIENTO A LMACENADO Para ejecutar el procedimiento almacenado por código, podemos usar un bloque anónimo PARÁMETROS PARA P ROCEDIMIENTOS A LMACENADOS Los procedimientos almacenados permiten el uso de parámetros Cada parámetro se separa por una coma (,) Sintaxis: «Nombre_param» |«tipo_param»| «tipo_dato» |«opciones»| Donde: Nombre_param: Nombre dado al parámetro Tipo_param: Define el tipo de parámetro Tipo_dato: Tipo de dato dado al parámetro Opciones: Se puede utilizar para dar un valor por defecto al parámetro T IPO DE PARÁMETROS Los parámetros pueden ser de entrada (IN), de salida (OUT), o ambos (IN OUT) Parámetros IN: Son aquellos de sólo lectura que se utilizan para ingresar valores al procedimiento. Por defecto, en el caso que no se especifique el tipo de parámetro, éste se asume como de entrada Parámetros OUT: Son aquellos de escritura en donde el procedimiento le asigna un valor para ser utilizado posteriormente por el bloque que lo haya invocado Parámetros IN OUT: Son aquellos que poseen todas las características de los dos tipos anteriores E JEMPLO U SO PARÁMETRO DE E NTRADA Dado el siguiente procedimiento Se puede utilizar de la siguiente forma: E JEMPLO U SO PARÁMETRO DE S ALIDA Dado el siguiente procedimiento Se puede utilizar de la siguiente forma: A SIGNACIÓN DE VALORES A LOS PARÁMETROS Para asignar valores a los parámetros estudiaremos dos notaciones: Posicional: Los valores son asignados en el mismo orden en que los parámetros se encuentran declarados Nominal: Los valores son asignados en cualquier orden explicitando al parámetro al cual se le está asignando E JEMPLO A SIGNACIÓN DE VALORES A PARÁMETROS POR NOTACIÓN POSICIONAL Dado el siguiente procedimiento La asignación de valores es de la siguiente forma: E JEMPLO A SIGNACIÓN DE VALORES A PARÁMETROS POR NOTACIÓN N OMINAL Dado el siguiente procedimiento La asignación de valores es de la siguiente forma: PARÁMETROS F ORMALES Y A CTUALES En la declaración de procedimientos que tienen parámetros, a éstos se les conoce como parámetros formales o ficticios La invocación de los procedimientos, consta de dos partes, el nombre del procedimiento y la lista de parámetros, los que también se conocen como parámetros actuales F UNCIONES A diferencia de los procedimientos almacenados, las funciones son utilizadas para que realicen cierta operatoria y que devuelvan un resultado al que invocó dicha función Sintaxis: Create [or Replace] Function «nombre_función» [(lista_parametros)] Return «tipo_dato» is ….. Return |»valor»|; End [«nombre_función»]; C ONSIDERACIONES PARA F UNCIONES Las consideraciones son las mismas que para los procedimientos almacenados Las reglas de parámetros de los procedimientos almacenados también se aplican a las funciones. La excepción viene dada porque sólo pueden ser de entrada (IN) Para eliminar una función se usa: Drop function «nombre_función»; E JEMPLO Función Declarada DE F UNCIÓN E JECUTAR F UNCIÓN Para invocar a la función, se puede realizar de distintas formas. Por ejemplo, se puede asignar el resultado directamente en una variable o utilizar una sentencia SELECT - INTO T RIGGER SOBRE TABLAS Los triggers (disparadores) son bloques asociados a una tabla y que se ejecutan automáticamente cuando ocurre una operación DML (Insert, Delete, Update) sobre esa tabla No es recomendable crear triggers muy complejos o una cantidad numerosa para una tabla, ya que la performance puede verse afectada Un trigger no puede llevar el comando Commit o Rollback (ni los bloques que dicho trigger invoque) Los triggers sobre tablas no son los únicos existentes. También existen sobre vistas, o sobre base de datos o esquema S INTÁXIS T RIGGER CREATE [OR REPLACE] TRIGGER «nombre_trigger» {BEFORE|AFTER} {DELETE|INSERT|UPDATE [OF col1, col2, ..., colN] [OR {DELETE|INSERT|UPDATE [OF col1, col2, ..., colN]...]} ON «nombre_tabla» [REFERENCING OLD as «nombre_anterior», NEW as «nombre_nuevo»] [FOR EACH ROW [WHEN («condicion»)]] DECLARE ……. BEGIN ...... [EXCEPTION] …. END «nombre_trigger»; S INTAXIS T RIGGER Donde: {BEFORE|AFTER} : Indica si el trigger se ejecuta antes o después de la sentencia que disparó al trigger {DELETE|INSERT|UPDATE [OF col1, col2, ..., colN] [OR {DELETE|INSERT|UPDATE [OF col1, col2, ..., colN]...]}: Indica cual (o cuales) evento está asociado al trigger. Opcionalmente, para el caso de actualización se puede especificar las columnas cuya modificación dispara al trigger [REFERENCING OLD as «nombre_anterior», NEW as «nombre_nuevo»]: Opcional. Asigna nombre a la forma como se referenciará a los registros antes o despues de la ejecución del (los) evento asociado [FOR EACH ROW [WHEN («condicion»)]]: Indica si el trigger se ejecuta a nivel de fila, es decir, por cada registro afectado por el trigger. Opcionalmente se puede agregar una condición para filtrar los registros afectados E JEMPLO Trigger Declarado DE TRIGGER E JEMPLO T RIGGER Para que se ejecute el trigger, debemos invocar la sentencia DML asociada (insert). Consideremos que dicho trigger asigna un identificador cada vez se ingresa un nuevo registro a la tabla auto Fijarse que en el insert no se asignó valor al campo «auto_id». Sin embargo, en la tabla aparece un valor. Eso implica que nuestro trigger ha funcionado VARIABLES OLD Y NEW Dentro del ámbito de un trigger existen dos variables que no es necesario declararlas y ambas son de tipo %ROWTYPE Dichas variables contienen una copia del registro antes (OLD) y después (NEW) de la acción de la sentencia DML asociada (ver ejemplo del trigger anterior) Para modificar el nombre de dichas variables se utiliza la clausula «REFERENCING» del trigger Estas variables son sólo válidas cuando el trigger es a nivel de fila VALORES PARA OLD Y NEW Sentencia OLD NEW Insert Null Valores a insertar Delete Valores originales Null Update Valores Originales Valores modificados P REDICADOS Dentro de un trigger se pueden utilizar predicados, que retornan valores booleanos, para identificar la acción que esta realizando Inserting: Devuelve verdadero si la instrucción que disparó el trigger fue un «Insert» Updating: Devuelve verdadero si la instrucción que disparó el trigger fue un «Update» Deleting: Devuelve verdadero si la instrucción que disparó el trigger fue un «Delete» E JEMPLO U SO P REDICADO E LIMINACIÓN Y D ESACTIVACIÓN Para eliminar un trigger se utiliza: Para desactivar un trigger se utiliza Alter trigger «nombre_trigger» disable; Para activar un trigger se utiliza Drop trigger «nombre_trigger»; Alter trigger «nombre_trigger» enable; Para activar todos los trigger de una tabla se utiliza Alter table «nombre_tabla» enable all triggers; TABLAS M UTANTES Uno de los errores mas comunes que se producen en la ejecución de un trigger es el de tabla mutante Una tabla mutante es aquella que está siendo modificada por una sentencia SQL (insert, delete, update) Lo anterior implica que dicha tabla no puede ser consultada La solución general mas recurrente (no siempre se puede aplicar) es realizar una copia de los registros que se modificarán por el trigger en una tabla temporal y luego sobre esta tabla temporal realizar las acciones requeridas AYÚDANOS A M EJORAR cesa.martinez@profesor.duoc.cl cmartinezc@duoc.cl FIN © César Martínez C. Profesor Instructor de Base de Datos Sede Puente Alto DUOC