4




Este es un pequeño ejemplo de como crear un Stored Procedure en mysql que no regrese nada.

Paso 1:
Como es comun en la programacion se tienen muchos errores y para crear un sp (Stored Procedure) se realiza a base de prueba/error, para eso ponemos en la primer linea esto:

DROP PROCEDURE IF EXISTS mysp;


el nombre del stored procedure es mysp

Paso 2:
se tiene que utilizar un delimitador, yo utilizo //
DELIMITER //

este delimitidor mas adelante se debe de cerrar.
con la sentencia
CREATE PROCEDURE mysp ()

indicamos la creacion del sp, el sp debe de tener un cuerpo y un final para eso usamos las etiquetas BEGIN y END

Entonces ya temenos esta parte de codigo

DELIMITER //
CREATE PROCEDURE mysp ()

BEGIN

END

//
DELIMITER ;#aqui es donde se cierra el delimitador


La instruccion DELIMITER ; esta ultima instruccion debe de tener un espacio antes del ";"

Paso 3:
Declaracion y asignacion de variables, la declaracion de variables dentro de un sp es de la siguiente forma.

DECLARE var1 INT DEFAULT 0; #variables enteras
DECLARE var2 VARCHAR(15); #variables varchar tambien le podemos decir strings


La asignacion se realiza de esta manera:

SET vat1 = "hola";


Tambien existe otra forma de aisgnarles valores que se ve mas adelante.

Paso 4: (opcional)
Podemos tener un ciclo dentro del sp de la siguiente forma.

WHILE v1 <= 10 DO
SET v1 = v1 +1;
END WHILE;


Llenar variables con resultados de un select

SELECT campo INTO variable FROM tabla LIMIT 1;


Para llenar las variables de este tipo el resultado del select solo tienes que regresar un registro, de lo contrario tendriamos un error, podemos llenar varias variables dentro del mismo select

SELECT campo1,campo2,campo3 INTO variable1,variable2,variable3 FROM tabla LIMIT 1;


Nuestro codigo hasta el paso 4 se veria asi:

DROP PROCEDURE IF EXISTS mysp;

DELIMITER //
  CREATE PROCEDURE mysp ()

   BEGIN
    DECLARE var1 INT DEFAULT 0;
    DECLARE var2 VARCHAR(15);

    WHILE var1 <= 10 DO

     SELECT campo INTO var2 FROM tabla LIMIT 1;
     SET var1 = var1 + 1; #var1 +=

    END WHILE;

   END

//
DELIMITER ;


para llamar al procedure se utiliza:

call mysp();


Eso es todo para un ejemplo sencillo !!!!