lunes, 8 de agosto de 2011

procedimientos

Un procedimiento es un subprograma que ejecuta una acción especifica y que no devuelve ningún valor. Un procedimiento tiene un nombre, un conjunto de parámetros (opcional) y un bloque de código.
    La sintaxis de un procedimiento almacenado es la siguiente:


CREATE [OR REPLACE] 
PROCEDURE <procedure_name> [(<param1> [IN|OUT|IN OUT] <type>, 
                             <param2> [IN|OUT|IN OUT] <type>, ...)] 
IS  -- Declaracion de variables locales
BEGIN
  -- Sentencias[EXCEPTION]  -- Sentencias control de excepcionEND [<procedure_name>];
 

El uso de OR REPLACE permite sobreescribir un procedimiento existente. Si se omite, y el procedimiento existe, se producirá, un error.
    La sintaxis es muy parecida a la de un bloque anónimo, salvo porque se reemplaza la seccion DECLARE por la secuencia PROCEDURE ... IS en la especificación del procedimiento.
    Debemos especificar el tipo de datos de cada parámetro. Al especificar el tipo de dato del parámetro no debemos especificar la longitud del tipo.
    Los parámetros pueden ser de entrada (IN), de salida (OUT) o de entrada salida (IN OUT). El valor por defecto es IN, y se toma ese valor en caso de que no especifiquemos nada.


CREATE OR REPLACE 
PROCEDURE Actualiza_Saldo(cuenta NUMBER, 
                          new_saldo NUMBER)
IS  -- Declaracion de variables locales
BEGIN
  -- Sentencias
  UPDATE SALDOS_CUENTAS 
	SET SALDO = new_saldo, 
            FX_ACTUALIZACION = SYSDATE
  WHERE CO_CUENTA = cuenta;
END Actualiza_Saldo;  
 
También podemos asignar un valor por defecto a los parámetros, 
utilizando la clausula DEFAULT  o el operador de asiganción (:=) . 
CREATE OR REPLACE 
PROCEDURE Actualiza_Saldo(cuenta NUMBER, 
                          new_saldo NUMBER DEFAULT 10 )
IS  -- Declaracion de variables locales
BEGIN
  -- Sentencias
  UPDATE SALDOS_CUENTAS 
	SET SALDO = new_saldo, 
            FX_ACTUALIZACION = SYSDATE
  WHERE CO_CUENTA = cuenta;
END Actualiza_Saldo; 
 
 Una vez creado y compilado el procedimiento almacenado podemos 
ejecutarlo. Si el sistema nos indica que el procedimiento se ha creado 
con errores de compilación podemos ver estos errores de compilacion con 
la orden SHOW ERRORS en SQL *Plus.
    Existen dos formas de pasar argumentos a un procedimiento 
almacenado a la hora de ejecutarlo (en realidad es válido para cualquier
 subprograma). Estas son:
  • Notación posicional: Se pasan los valores de los parámetros en el 
  • mismo orden en que el procedure los define.
 
BEGIN	Actualiza_Saldo(200501,2500);
        COMMIT;
END; 
 



 

No hay comentarios:

Publicar un comentario