PL/SQL Francisco Moreno Universidad Nacional.

Slides:



Advertisements
Presentaciones similares
SQL Sigla del nombre “Structured Query Language”.
Advertisements

Maestría en Bioinformática Bases de Datos y Sistemas de Información SQL: DML Ing. Alfonso Vicente, PMP
Maestría en Bioinformática Bases de Datos y Sistemas de Información Otros objetos de Base de Datos Ing. Alfonso Vicente, PMP
PL/SQL Francisco Moreno Universidad Nacional.
Características Objeto Relacionales en Oracle Francisco Moreno Universidad Nacional.
Características Objeto Relacionales en Oracle
PL/SQL Francisco Moreno Universidad Nacional.
1 BD Activas: Motivación zLos SGBD convencionales son “pasivos”. Sólo ejecutan preguntas o transacciones realizadas por los usuarios o por los programas.
PL/SQL Francisco Moreno Universidad Nacional. Introducción al PL/SQL ¿Por qué PL/SQL? A pesar de que SQL tiene mecanismos de control condicional (cláusula.
Bases de Datos Relacionales
16/04/ Sesión 11 Funciones y procedimientos Ing. Ricardo Inquilla.
PL/SQL Francisco Moreno Universidad Nacional.
PL/SQL Francisco Moreno Universidad Nacional.
Ing. Ricardo Carlos Inquilla Quispe
Procedimientos Almacenados Funciones Agregadas
UNITA - IBARRA TRIGGERS
Lenguaje Estructurado de Consultas
John Freddy Duitama M.U.de.A. Facultad de Ingeniería. Creación del esquema de Una Base de Datos. John Freddy Duitama Muñoz. Facultad de Ingeniería. U.de.A.
PL/SQL Francisco Moreno Universidad Nacional.
TRIGGERS EN ORACLE 8 J. Iriarte S. España
Triggers(Disparadores)
Características Objeto-Relacionales en Oracle Francisco Moreno Universidad Nacional.
John Freddy Duitama M.U.de.A. Facultad de Ingeniería. Creación del esquema de Una Base de Datos. John Freddy Duitama Muñoz. Facultad de Ingeniería. U.de.A.
SQL: DDL Francisco Moreno. SQL: DDL DDL: Lenguaje de Definición de Datos Permite crear objetos en la BD Tipos de objetos: - Tablas: corresponden a las.
Base de datos Francisco Castro. Creación de una tabla drop table TABLA cascade constraints; /*==============================================================*/
PUESTO-TRABAJO (Código-Puesto, Empresa, Sueldo, DNI- Contratado) TITULADO (DNI-Titulado, Nombre, Apellidos, Dirección) TITULACION (Iden-Titulación, Nombre,
Comandos de SQL Prog. Orientada a Eventos. Inserción de datos (INSERT) INSERT….VALUES INSERT INTO Tabla1 (Columna1, Columna2…) VALUES (‘ValorAlfa’, ValorNum…);
Lenguaje Estructurado de Consultas
Sentencias DDL y DML PostgreSQL. Base de Datos I – Fundamentos Básicos PostgreSQL PostgreSQL es un servidor de base de datos relacional libre bajo la.
6 Triggers ORACLE - II Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega.
Apuntes PL-SQL Triggers I.
3 Cursores ORACLE Bases de datos II I-2014 Universidad del Cauca In. Wilson Ortega Bases de datos II I-2014 Universidad del Cauca In. Wilson Ortega.
Administración de Base de Datos Integridad Prof Mercy Ospina Torres Prof Renny A. Hernandez
Mtr. Adrián Monge Monge Educación 2015 Maestría, Mención en Administración de Proyectos ULACITMaestría, Mención en Administración de Proyectos 2012 Licenciatura,
Base de Datos I – Ing. Mary Carlota Bernal J.  Cada instrucción PL/SQL tiene asociado internamente un cursor  Los cursores en PL/SQL pueden ser de dos.
DML Transact SQL Sesión X Triggers. Duración 2 Horas.
6 Triggers ORACLE Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega.
6 Copyright © 2004, Oracle. Todos los derechos reservados. Trabajar con Tipos de Dato Compuestos.
Lenguaje MySQL, DDL (Lenguaje de definición de datos) Ing. Linda Masias Morales.
6 Triggers ORACLE - III Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega Bases de datos II I-2014 Universidad del Cauca Ing. Wilson Ortega.
Crear una tabla (create table - sp_tables - sp_columns - drop table) Para ver las tablas existentes creadas por los usuarios en una base de datos usamos.
COMANDOS BÁSICOS MYSQL BASES DE DATOS 2 UNIVERSIDAD DE LA AMAZONIA.
Conferencia 12. Temas Avanzados de Integridad de Bases de Datos.
Francisco Moreno Bases de Datos II Universidad Nacional
PL/SQL Francisco Moreno Universidad Nacional.
SQL: Structured Query Language
Aidan Hogan CC Bases de Datos Primavera 2016 Clase 11: Integridad, Transacciones, ACID (I) Aidan Hogan
Características Objeto Relacionales en Oracle
Lenguaje de manipulación de datos
SEGURIDAD SQL Usuarios, privilegios y perfiles.
Tipos de datos en MYSQL YEAR: Año. “YYYY” o “YY”
BASE DE DATOS IUPSM CLASE PRACTICA. PROF. ING. JOSE L GUZMAN H.
Stored Procedures Firebird.
SQL Prof. Martín Contreras.
SQL 2: Structured Query Language
SQL: structured Query Language
UN DISPARADOR O TRIGGER es un procedimiento que se ejecuta cuando se cumple una condición establecida al realizar una operación. Es una rutina autónoma.
Lenguaje Estructurado de Consultas
5. SQL Procedural.
Lenguaje de Manipulación de Datos
SQL Lenguaje de definición de datos
UN EJEMPLO DE LECTURA CONSISTENTE EN INNODB
BD Activas: Motivación
Unidad V :- Integridad de datos.
Modificación de datos. Introducción Uso de transacciones Inserción de datos Eliminación de datos Actualización de datos Consideraciones acerca del rendimiento.
Normalmente emparejamos tablas que están relacionadas entre sí y una de las columnas de emparejamiento es clave principal, pues en este caso, Cuando una.
Características Objeto Relacionales en Oracle
TRIGGERS VISTAS Y PROCESOS Ing. Fabiola Nilda Perez Oliver
CC Bases de Datos Otoño Clase 10: SQL: Vistas y Disparadores
El SQL es el lenguaje estándar ANSI/ISO de definición, manipulación y control de bases de datos relacionales. La sigla que se conoce como SQL corresponde.
Transcripción de la presentación:

PL/SQL Francisco Moreno Universidad Nacional

Disparadores (Triggers) Los triggers son bloques PL/SQL que se ejecutan de manera implícita cuando se ejecutan operaciones INSERT, DELETE, UPDATE a una tabla* Se usan principalmente para establecer reglas complejas de integridad y labores de auditoría. * También existen triggers que se disparan ante otros eventos y objetos de la BD (LOGON, LOGOFF, STARTUP, BEFORE DDL, entre otros.) ¿Por ejemplo?

Un trigger tiene asociado: Un evento Un momento Un tipo El evento se refiere a la operación que se efectúa sobre la tabla (INSERT, DELETE o UPDATE).

El momento, se refiere a cuándo se dispara el trigger en relación con el evento. Sus posibles valores son BEFORE y AFTER*. El tipo indica el número de veces que el cuerpo del trigger se ejecuta: por la operación en conjunto (trigger de operación) o por cada fila procesada (trigger de fila). En este último caso se debe adicionar la cláusula FOR EACH ROW * Y también INSTEAD OF para vistas.

Los triggers se ejecutan implícitamente cuando ocurre el evento Haciendo las diferentes combinaciones, para una tabla se pueden crear máximo doce tipos de triggers Se pueden tener varios triggers del mismo tipo asociados con una misma tabla Los triggers se ejecutan implícitamente cuando ocurre el evento Normalmente en los triggers no se pueden* usar las sentencias COMMIT, ni ROLLBACK * Es posible con autonomous transactions, por simplicidad se omitirán.

Para especificar triggers de fila Sintaxis esencial de un trigger: CREATE [OR REPLACE] TRIGGER nombre_trigger momento evento ON tabla [FOR EACH ROW [WHEN condición]] bloque de PL/SQL Si el evento es UPDATE, se puede(n) especificar la(s) columna(s) que dispararán el trigger con la palabra OF (si no se especifican, el trigger se dispara con cualquier columna de la tabla que sea actualizada) El bloque comienza con la palabra DECLARE o BEGIN Para especificar triggers de fila

Evento Valor anterior Valor nuevo INSERT NULL El valor que se va a insertar DELETE El valor antes del borrado UPDATE El valor antes de la actualiza- ción El valor después de la actualiza-ción Si es un trigger de fila, se puede acceder al valor de una columna antes de la actualización con :OLD.nomcolumna y al valor después de la actualización con :NEW.nomcolumna

Ejemplo: Trigger de operación CREATE TABLE PRODUCTO(codigo NUMBER(6) PRIMARY KEY, precio NUMBER(6)); CREATE OR REPLACE TRIGGER control_insercion_productos BEFORE INSERT ON producto BEGIN IF TO_CHAR(SYSDATE,'D') = '7'THEN RAISE_APPLICATION_ERROR(-20506,'¡No los domingos!'); END IF; END; / La instrucción RAISE_APPLICATION_ERROR abortará la operación de inserción si esta se intenta hacer un domingo. Domingo (puede ser 1 o 7 según la config. del NLS) SQLCODE y SQLERRM asignados por el usuario

BEGIN INSERT INTO producto VALUES(1,10); EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLCODE || SQLERRM); END; /

Ejemplo: Trigger de Fila Sean las tablas: CREATE TABLE cuenta( nro_cta NUMBER(10) PRIMARY KEY, saldo NUMBER(8) NOT NULL CHECK (saldo >= 0) ); INSERT INTO cuenta VALUES(1, 100); INSERT INTO cuenta VALUES(2, 200); CREATE TABLE retiro( nro_retiro NUMBER(10) PRIMARY KEY, cta NUMBER(10) REFERENCES cuenta NOT NULL, valor NUMBER(8) NOT NULL CHECK (valor > 0)

Cuando se va a insertar un retiro: - Si su valor es mayor al saldo de la cuenta, se debe rechazar la transacción. Si el retiro se puede hacer, se debe actualizar el saldo de la cuenta

CREATE OR REPLACE TRIGGER control_retiro BEFORE INSERT ON retiro FOR EACH ROW DECLARE saldo_cta cuenta.saldo%TYPE; BEGIN SELECT saldo INTO saldo_cta FROM cuenta WHERE nro_cta = :NEW.cta; IF saldo_cta < :NEW.valor THEN RAISE_APPLICATION_ERROR(-20505,'¡Fondos insuficientes!'); ELSE UPDATE cuenta SET saldo = saldo - :NEW.valor WHERE nro_cta = :NEW.cta; END IF; END; / ¿Qué pasa si el valor del retiro fuese negativo?

INSERT INTO retiro VALUES(22, 1, 70); Ejercicio: Analizar las consecuencias de actualizar o borrar tanto en la tabla cuenta como en la tabla retiro. Por ejemplo: ¿sería válido actualizar el valor de un retiro?

Un ejemplo con XML CREATE TABLE pago(id NUMBER(4) PRIMARY KEY, d XMLTYPE); CREATE OR REPLACE TRIGGER control_porc BEFORE INSERT ON pago FOR EACH ROW DECLARE p1 VARCHAR2(20); p2 VARCHAR2(20); BEGIN p1 := :NEW.d.EXTRACT('/Emp/Porcen1/text()').getstringval(); p2 := :NEW.d.EXTRACT('/Emp/Porcen2/text()').getstringval(); IF (TO_NUMBER(p1) + TO_NUMBER(p2)) != 100 THEN RAISE_APPLICATION_ERROR(-20505,'¡Los porc. no suman 100!'); END IF; END; /

Un ejemplo con XML INSERT INTO pago VALUES (100, XMLType('<Emp cod="5"> <Porcen1>80</Porcen1> <Porcen2>18</Porcen2> </Emp>')); (200, XMLType('<Emp cod="7"> <Porcen2>20</Porcen2>

La cláusula WHEN Sirve para agregar una condición adicional para activar el trigger Dentro de la condición WHEN para referirse a NEW y a OLD no se usan los dos puntos (:) Ejemplo. Sea: CREATE TABLE auditoria (usuario VARCHAR2(20),cuando DATE, cta NUMBER(6), aumento NUMBER(10));

Sin usar WHEN: Usando WHEN: CREATE or REPLACE TRIGGER quien_sube_retiro BEFORE UPDATE OF valor ON retiro FOR EACH ROW WHEN (NEW.valor > OLD.valor) BEGIN INSERT INTO auditoria VALUES(USER, SYSDATE, :old.cta, :NEW.valor - :OLD.valor ); END; / CREATE or REPLACE TRIGGER quien_sube_retiro BEFORE UPDATE OF valor ON retiro FOR EACH ROW BEGIN IF :NEW.valor > :OLD.valor THEN INSERT INTO auditoria VALUES(USER, SYSDATE, :old.cta, :NEW.valor - :OLD.valor ); END IF; END; / Conclusión: WHEN evita el uso de un IF explícito dentro de la sección ejecutable del trigger

El orden de ejecución de los triggers es el siguiente: La ejecución de un trigger es transaccional, es decir, si un trigger de fila afecta n registros y si uno solo de ellos aborta, entonces todo el proceso se aborta. El orden de ejecución de los triggers es el siguiente: 1. Se ejecutan (si los hay*) los triggers BEFORE de operación 2. Se ejecutan sucesivamente para cada fila: - (Si los hay*) los triggers BEFORE de fila - Se ejecuta la operación DML correspondiente** - (Si los hay*) los triggers AFTER de fila 3. Se ejecutan (si los hay*) los triggers AFTER de operación * Si hay varios triggers con idéntica definición (a partir de Oracle 8i), el orden de ejecución entre ellos es “aleatorio”  Ver diapositiva final. ** Tarea: analizar en relación con los triggers cuando se realizan las verificaciones de integridad (clave primaria, foránea, checks, entre otras).

CREATE TABLE jefe(cc NUMBER(8) PRIMARY KEY, salario NUMBER(8)); INSERT INTO jefe VALUES(10, 400); INSERT INTO jefe VALUES(20, 200); CREATE OR REPLACE TRIGGER bef_upd_row1 BEFORE UPDATE ON jefe FOR EACH ROW BEGIN DBMS_OUTPUT.PUT_LINE('Bef Upd fila1 cc:'||:NEW.cc); DBMS_OUTPUT.PUT_LINE(:NEW.salario); IF :NEW.salario > 100 THEN :NEW.salario := 0; END IF; END; /

Ahora para comprobar el funcionamiento: UPDATE jefe set salario = 100; CREATE OR REPLACE TRIGGER bef_upd_row2 BEFORE UPDATE ON jefe FOR EACH ROW BEGIN DBMS_OUTPUT.PUT_LINE('Bef Upd fila2 cc:'||:NEW.cc); DBMS_OUTPUT.PUT_LINE(:NEW.salario); :NEW.salario := :NEW.salario + 50; END; / Ahora para comprobar el funcionamiento: UPDATE jefe set salario = 100;

Resultados Bef Upd fila2 cc:10 100 Bef Upd fila1 cc:10 150 Bef Upd fila2 cc:20 Bef Upd fila1 cc:20 Triggers de fila afectando a la fila con cc 10 Triggers de fila afectando a la fila con cc 20 Ejercicio: intercambiar los nombres de bef_upd_row1 y de bef_upd_row2 y ejecutar todo de nuevo y ver que sucede

Tarea: consultar las opciones: IF INSERTING …, IF UPDATING…, IF DELETING… Oracle 11g soporta la opción FOLLOWS. También se soportan Compound Triggers. Ver: https://oracle-base.com/articles/11g/trigger-enhancements-11gr1 Permite codificar varios triggers en uno solo