PL SQL
PL SQL
PL SQL
BASES DE DATOS
PRCTICA: OBJETIVOS:
8.
INTRODUCCIN A PL/SQL
Conocer los fundamentos bsicos de PL/SQL y aprender los componentes principales de un bloque PL/SQL. MATERIAL: ORACLE 9i versin para WINDOWS XP BIBLIOGRAFIA: ORACLE: Introduction to ORACLE 9i: PL/SQL. Student Guide. 2001. OREILLY: ORACLE PL/SQL Programming 2nd Edition. 2000.
BASES DE DATOS
CONTENIDO: 1. Introduccin 2. Variables 2.1. Declaracin de variables 2.2. Asignacin de valores a variables 2.3. Atributo %TYPE 2.4. Variables BOOLEANAS 3. rdenes ejecutables PL/SQL 3.1. Comentarios PL/SQL 3.2. Funciones PL/SQL 3.3. Conversin de tipos 3.4. Operadores 4. Entrada/Salida 4.1. Entrada de datos 4.2. Salida de datos 5. rdenes SQL en PL/SQL 5.1. SELECT 5.2. INSERT, DELETE, UPDATE 6. Estructuras de control 6.1. IF-THEN-ELSE 6.2. LOOP 6.3. FOR 6.4. WHILE Despus de completar esta prctica, el alumno debera ser capaz de: - Escribir bloques PL/SQL - Manejar instrucciones SQL dentro de bloques PL/SQL. Esquema de Trabajo Los ejemplos mostrados en esta prctica estn basados en el siguiente esquema relacional: Empleados (id, apellidos, nombre, salario, dep, fecha_alta, email) Departamentos (num, nombre, edificio) Empleados.dep -> Departamentos
BASES DE DATOS
1. Introduccin PL/SQL es un lenguaje de programacin estructurado. Es un lenguaje procedimental que ampla la funcionalidad de SQL, aadiendo estructuras habituales en otros lenguajes de programacin, entre las que se encuentran: Variables y Tipos Estructuras de control Procedimientos y Funciones Tipos de Objetos y Mtodos. La unidad bsica en PL/SQL es el bloque. Todos los programas PL/SQL estn compuestos por bloques que pueden estar anidados. Un bloque PL/SQL est compuesto de tres partes principales: seccin declarativa (opcional). Contiene las variables, constantes ... seccin ejecutable (obligatoria). Contiene rdenes SQL para manipular datos de la base de datos y rdenes PL/SQL para manipular los datos del bloque seccin de excepciones (opcional). Especifica las acciones a realizar en caso de error o cuando se producen excepciones en la ejecucin.
La estructura general es: [DECLARE variables, constantes, excepciones de usuario...] BEGIN rdenes SQL rdenes PL/SQL [EXCEPTION acciones a realizar al ocurrir un error] END; / Para ejecutar un bloque PL/SQL siempre hay que colocar al final la barra /. Podemos crear diferentes tipos de bloques: Bloques annimos: Se construyen de forma dinmica y se suelen ejecutar una sola vez. Bloques nominados: Igual que los annimos pero con una etiqueta que les da nombre. Subprogramas: Procedimientos, paquetes y funciones, almacenados en la base de datos y que se ejecutan en mltiples ocasiones. Los subprogramas se ejecutarn mediante una llamada.
BASES DE DATOS
Disparadores (Triggers): Bloques nominados que se almacenan en la base de datos y que se ejecutan ante algn suceso.
Para poner nombre a un bloque se le pone una etiqueta antes del DECLARE encerrado por <<...>>. Por ejemplo para darle el nombre Mi_Bloque a un bloque PL/SQL pondramos: <<Mi_Bloque>> DECLARE BEGIN END; /
2. Variables Las variables se definen en la seccin declarativa de los bloques PL/SQL dnde tambin pueden inicializarse. La asignacin de nuevos valores a las variables puede hacerse en la parte ejecutable del bloque. Pueden utilizarse para pasar valores como argumentos a subprogramas. Estas podrn ser de tipo IN (variable de entrada, OUT, variable de salida o INOUT, variable de entrada/salida). Tambin podrn utilizarse para almacenar valores devueltos o requeridos por una orden SQL. Todas las variables tienen un tipo. Los posibles tipos de una variable son: Escalar. Almacenan un valor nico. Son los mismos que los de las columnas de las tablas (VARCHAR2, NUMBER, DATE, CHAR, LONG, LONG_RAW, BINARY_INTEGER, LAW_INTEGER) ms el BOOLEAN Compuesto. Grupos de datos: tablas PL/SQL, registros... Puntero. Designan elementos de otros programas. LOB (Large OBjects). Almacenan gran cantidad de informacin. Las variables de tipo LOB permiten almacenar datos no estructurados (imgenes, texto...) de hasta 4 GB de tamao
BASES DE DATOS
2.1.Declaracin de variables Sintaxis: <identificador> [CONSTANT] <tipo_de_dato> [NOT NULL] [{:= | DEFAULT <expresin>}]; Ejemplo: DECLARE fecha DATE; dep_num NUMBER(2) NOT NULL := 10; ciudad VARCHAR2(10) := Ciudad Real; Km_a_milla CONSTANT NUMBER := 1.4; Las variables declaradas como NOT NULL siempre deben ser inicializadas. La inicializacin puede hacerse utilizando := o la palabra reservada DEFAULT. Si una variable no se inicializa contendr el valor NULL. Las constantes deben ser inicializadas. 2.2. Asignacin de valores a variables Sintaxis: <identificador> := <valor>; 2.3. Atributo %TYPE El atributo %TYPE se utiliza para declarar una variable con el mismo tipo que una columna de una tabla o que otra variable definida anteriormente. Sintaxis: <identificador> {<tabla>.<columna> | <nombre_variable>}%TYPE; Ejemplo: var_nombre Empleados.nombre%TYPE; balance NUMBER; balance_minimo balance%TYPE := 10;
BASES DE DATOS
2.4.Variables BOOLEANAS Las variable BOOLEANAS pueden tomar el valor TRUE, FALSE o NULL. Las variables pueden combinarse mediante operadores lgicos (NOT, AND, OR). Las expresiones pueden devolver valores BOOLEANOS utilizando operadores relacionales (<, <=...).
3. rdenes Ejecutables 3.1. Comentarios en PL/SQL Pueden aadirse comentarios al cdigo. Estos comentarios pueden ser especificados con: /*comentario ms comentario */ -- comentario de lnea 3.2. Funciones PL/SQL Las funciones utilizables en SQL (LOWER, UPPER, INITCAP, CANCAT, SUBSTR, LENGTH, ROUND, TRUNC, MOD, MONTHS_BETWEEN, ADD_MONTHS, NEXT_DAY, LAST_DAY) excepto las de agrupamiento (ya que estas se aplican sobre una columna de una tabla). 3.3. Conversin de tipos Existen funciones de conversin de tipos: TO_CHAR, TO_DATE, TO_NUMBER Sintaxis: TO_CHAR (<valor>, <formato>) TO_DATE(<valor>, <formato>) TO_NUMBER(<valor>, <formato>) 3.4.Operadores Los operadores en PL/SQL son los mismos que para SQL: Aritmticos, Concatenacin, Parntesis. Y adems, existe el operador exponencial (**). Lgicos,
BASES DE DATOS
4. Entrada/Salida Los programas PL/SQL suelen realizar operaciones especficas sin interactuar con el operador. Sin embargo, existen algunas funciones que nos pueden ayudar a depurar programas y a interactuar con el usuario mostrando datos por pantalla y pidiendo datos al usuario. 4.1. Salida de datos Para mostrar una cadena por pantalla podemos utilizar: DBMS_OUTPUT.PUT_LINE(<cadena de caracteres>); Si los datos a mostrar no son cadenas puede utilizarse la function TO_CHAR() para transformarlo, y el operador || para concatenar.
El paquete DBMS_OUTPUT implementa una cola, en la cual se van almacenando los mensajes de salida. Si queremos que los mensajes aparezcan por pantallas tenemos que activar la opcin SERVEROUTPUT: SET ServerOutput ON; 4.2. Entrada de datos Cuando trabajamos pidiendo datos al usuario es habitual especificar la opcin SET VERIFY OFF para evitar que el sistema nos muestre el valor que tena la variable antes y que nos confirme el nuevo valor que toma. Para pedir datos al usuario se utiliza una variable de substitucin, dentro del cdigo fuente del bloque PL/SQL, si esta variable no est inicializada, se le pedir el valor al usuario: SET ServerOutput ON; SET VERIFY OFF; DECLARE vv NUMBER :=&v; BEGIN DBMS_OUTPUT.PUT_LINE('Valor de v: '||vv); END; /
BASES DE DATOS
5. rdenes SQL en PL/SQL Podemos utilizar instrucciones SQL dentro de los bloques PL/SQL para recuperar datos de la base de datos o para actualizar los datos que contiene. 5.1. SELECT Sintaxis: SELECT <lista> INTO {<variable>[, <variable>, ...] | <registro>} FROM <tabla> WHERE <condicin>; El SELECT almacenar los valores que obtenga en las variables indicadas tras INTO y en el mismo orden. Es obligatorio incluir la clusula INTO. El SELECT debe prepararse para que slo devuelva una fila. Ejemplo: DECLARE v_apellidos VARCHAR2(50); v_nombre VARCHAR2(30); BEGIN SELECT apellidos, nombre INTO v_apellidos, v_nombre FROM Empleados WHERE id=5; END; 5.2. INSERT, UPDATE, DELETE La sintaxis no vara: INSERT INTO tabla VALUES(...); UPDATE tabla SET valor = expresin WHERE condicin; DELETE FROM tabla WHERE condicin;
BASES DE DATOS
La nica novedad es que en las expresiones y en las condiciones podemos utilizar variables PL/SQL. 6. Estructuras de control 6.1. Orden IF El funcionamiento de la estructura IF es el habitual. Su Sintaxis es la siguiente: IF <expresin1> THEN <Secuencia_ordenes1>; [ELSIF <expresin2> THEN <Secuencia_ordenes2>;] . [ELSE <Secuencia_ordenesN>;] END IF; Ejemplo: SET ServerOutput ON; SET VERIFY OFF; DECLARE v_num NUMBER := &v; BEGIN IF v_num < 50 THEN DBMS_OUTPUT.PUT_LINE('Valor pequeo'); ELSIF v_num < 100 THEN DBMS_OUTPUT.PUT_LINE('Valor mediano'); ELSE DBMS_OUTPUT.PUT_LINE('Valor grande'); END IF; END; /
BASES DE DATOS
6.2. Orden LOOP Los bucles LOOP son bucles que se ejecutan siempre, para salir de ellos tendremos que poner una instruccin de salida dentro del bucle. Su Sintaxis es: LOOP [EXIT WHEN <condicin>] END LOOP; Ejemplo: SET ServerOutput ON; SET VERIFY OFF; DECLARE num NUMBER :=1; BEGIN LOOP DBMS_OUTPUT.PUT_LINE('Valor: '|| num); num := num +1; EXIT WHEN num > 10; END LOOP; END; / 6.3.rden FOR Los bucles FOR se repiten un nmero determinado de veces. Sintaxis: FOR <contador> IN <min>..<max> [REVERSE] LOOP ... END LOOP; Ejemplo: SET ServerOutput ON; SET VERIFY OFF; DECLARE num NUMBER; BEGIN FOR num IN 1..10 LOOP DBMS_OUTPUT.PUT_LINE('Valor: '|| num); END LOOP; END; /
10
BASES DE DATOS
6.4.rden WHILE Los bucles WHILE son iguales que en otro lenguajes de programacin. Sintaxis: WHILE <condicion> LOOP ... END LOOP; Ejemplo: SET ServerOutput ON; SET VERIFY OFF; DECLARE num NUMBER:=1; BEGIN WHILE num <=10 LOOP DBMS_OUTPUT.PUT_LINE('Valor: '|| num); num := num + 1; END LOOP; END; /
11
BASES DE DATOS
EJERCICIOS PRCTICA 8 INTRODUCCION A PL/SQL Para realizar estos ejercicios es necesario recordar la estructura del esquema de la base de datos ACADEM empleada en prcticas anteriores:
DEPARTAMENTOS (codigo, nombre) AREAS (codigo, nombre, departamento) PROFESORES (codigo, apellido1, apellido2, nombre_pila, activo, categoria, dedicacion, area) ASIGNATURAS (siglas, nombre, creditos, curso, anualidad, clase, horas_teoria, horas_practica, grupos_teoria , grupos_practica, alumnos) LOCALES (codigo, nombre, docente, capacidad, edificio, situacion) GRUPOS (curso, clase, codigo, nombre) DOCENCIA (id, curso, clase, grupo, siglas, profesor, local, dia, hora, periodicidad) areas.departamento departamentos profesores.area areas docencia.curso, clase, grupo grupos docencia.profesor profesores docencia.local locales docencia.siglas asignaturas
1. Escribir un bloque PL/SQL que calcule la media de dos nmeros dados por el usuario. 2. Escribir un bloque PL/SQL que pida dos identificadores de profesores y determine cual de los dos est ms cerca de cero o si son iguales 3. Escribir un bloque PL/SQL que convierta una determinada cantidad expresada en segundos a horas, minutos y segundos. 4. Mostrar el contenido de una variable que contenga la capacidad total de todas las aulas del edificio de Informtica (EUI) 5. Insertar una fila en la tabla local con la capacidad total de los espacios de magisterio (EGB) (poner como nombre de edificio TOT, inventarse el contenido del resto de las columnas). Obtener la capacidad mxima de entre todas las clases del edificio de Informtica (EUI). Restar, de la capacidad de la fila insertada, el ltimo valor obtenido actualizar la fila correspondiente en la tabla. Eliminar las filas del edificio TOT.
12