PDF de programación - Procedimientos y Funciones - MySQL básico

Imágen de pdf Procedimientos y Funciones - MySQL básico

Procedimientos y Funciones - MySQL básicográfica de visualizaciones

Publicado el 11 de Julio del 2020
311 visualizaciones desde el 11 de Julio del 2020
48,8 KB
9 paginas
Creado hace 8a (15/04/2012)
http://dev.mysql.com/doc/refman/5.0/es/index.html

MySQL básico

Procedimientos y Funciones


A partir de mysql 5.0, es posible definir rutinas en MySQL. Éstas son funciones
y procedimientos que están almacenadas en el servidor de bases de datos y que pueden
ser ejecutadas posteriormente. Las funciones (stored functions) regresan un resultado y
pueden ser utilizadas en expresiones (de la misma manera en que se usan las funciones
de MySQL). Los procedimientos (stored procedures) no regresan ningún valor
directamente. Sin embargo, soportan tipos de parámetros cuyo valor puede fijarse en el
interior del procedimiento, de tal manera que dicho valor pueda ser utilizado una vez
que el procedimiento haya terminado.


Generalmente se usa una función para calcular un valor y regresarlo para
utilizarlo posteriormente en alguna expresión. Un procedimiento se usa para producir un
efecto o una acción sin necesidad de regresar algún valor. Si se necesita regresar más de
un valor, no se puede utilizar una función, sin embargo, se puede crear un
procedimiento cuyos parámetros tengan la propiedad de OUT, los cuales puedan ser
utilizados en expresiones una vez que el procedimiento se haya ejecutado.

Las ventajas del uso de las rutinas anteriores son las siguientes:


• Extienden la sintaxis de SQL al agregar ciclos e instrucciones de saltos.
• Proveen un mecanismo de manejo de errores.
• Debido a que están almacenadas en el servidor, todo el código necesario para
definirlas necesita ser mandado por la red solamente una vez, en el momento de
su creación y no cada vez que es invocada. Lo anterior reduce sobrecarga.



Para crear una función o un procedimiento se deben usar las instrucciones CREATE

FUNCTION o CREATE PROCEDURE.

Ejemplo:

CREATE FUNCTION func1 (date1 DATE, date2 DATE) RETURNS INT
BEGIN
DECLARE edad INT;
SET edad = (YEAR(date2) - YEAR(date1));
RETURN edad;
END


Después de haber desarrollado la función anterior, podemos usarla de la

siguiente manera:


SELECT func1('1985-12-25’, CURDATE());

También se puede utilizar sintaxis parecida a la de pgplsql de la siguiente forma:

CREATE FUNCTION `probando`(tipo varchar(25)) RETURNS double
BEGIN

declare pasta double;
select sueldo into pasta from gente where nombre=tipo;
if(pasta is null) then

return 0;

return pasta;

else

end if;

END


Un procedimiento es similar a una función, con la diferencia de que no puede

regresar ningún valor, así que no incluye ninguna instrucción RETURN. Ejemplo:

CREATE PROCEDURE proc1(anio_nacimiento INT)
SELECT nombre, apellido
FROM templa
WHERE YEAR(fechnac) = anio_nacimiento:


El resultado del procedimiento anterior no es regresado como valor, sino como
resultset al cliente que lo manda llamar. Para invocar un procedimiento se debe utilizar
la instrucción CALL. Ejemplo:


CALL proc1(1964);



El ejemplo anterior ilustra una cosa que los procedimientos pueden hacer y que
las funciones no: Los procedimientos pueden acceder a tablas. A su vez, se puede
definir un procedimiento que realiza alguna operación determinada en una tabla y que
incluya en su definición un parámetro como IN o INOUT para regresar el valor del
procedimiento cuando éste regrese. Esta técnica también es utilizada si se necesita
regresar más de un valor, ya que una función no puede regresar más de un valor.


De manera predeterminada, un parámetro de un procedimiento es de tipo IN; un
parámetro definido de esta manera se recibe en el procedimiento pero cualquier
modificación realizada en él no se conservará una vez que el procedimiento termine. Un
parámetro OUT es lo contrario: el procedimiento asignará algún valor al parámetro, el
cual podrá ser accedido una vez que el procedimiento haya regresado. Un parámetro
INOUT permite mandar un valor al procedimiento y obtenerlo de vuelta.

El siguiente ejemplo ilustra lo anterior:

CREATE PROCEDURE proc2 (anio_nacimiento INT, OUT cuantos INT)
BEGIN

DECLARE c CURSOR FOR
SELECT COUNT(*)
FROM templa
WHERE YEAR(fechnac) = anio_nacimiento;
OPEN c;



FETCH c into cuantos;
CLOSE c;



END;


El procedimiento anterior no solamente invoca la instrucción SELECT y asigna
el valor de COUNT(*) a una variable. Si hiciera eso, el resultado del query hubiera sido
desplegado en la pantalla del cliente. Para evitar ese despliegue, el procedimiento
inicializa un cursor y lo usa para ejecutar la instrucción SELECT. De esta manera, el
resultado del SELECT se queda dentro del procedimiento de tal manera que pueda
procesar el resultado directamente. Para utilizar un cursor, se debe declarar asociándolo
al query que será ejecutado. Después se deberá abrir el cursor, obtener los renglones
resultantes y por último se deberá cerrar el cursor.


Ahora se puede crear una función que haga uso de este procedimiento para

recibir un año y devolver el número de empleados nacidos en ese año

CREATE FUNCTION func2(a int) RETURNS int
BEGIN

declare b int;
call proc2(a,b);
return b;

END



Por último se puede usar la función mediante select func2(1964); 1


Estructuras de Control

Las estructuras de control permiten, como su nombre lo indica, controlar el flujo
de las instrucciones dentro de un procedimiento o una función. En la siguiente
explicación, cada ocurrencia de instrucción(es), indica una lista de una o más
instrucciones, cada una de las cuales debe terminar con ";".


Algunas de las estructuras pueden llevar una etiqueta (BEGIN, LOOP, REPEAT
y WHILE). Las etiquetas no son sensibles a las mayúsculas o minúsculas pero deben
seguir las siguientes reglas:


Si una etiqueta aparece al principio de alguna estructura, deberá también

aparecer al final de la misma.


Una etiqueta no deberá aparecer al final de una estructura sin tener su

correspondiente pareja al principio de la misma.


BEGIN ... END
BEGIN [instrucción(es)] END

etiqueta: BEGIN [instrucción(es)] END [etiqueta]


La estructura BEGIN … END se utiliza para agrupar un conjunto de
instrucciones. Si un procedimiento o una función necesita contener más de una

instrucción, éstas deberán aparecer dentro de un BEGIN … END. De la misma manera,
si el procedimiento o función contienen una rutina DECLARE, ésta deberá aparecer al
principio del bloque BEGIN … END.

CASE
CASE [expresión]
WHEN expresión1 THEN instruccion(es)
[WHEN expresión2 THEN instruccion(es)]
...
[ELSE instruccion(es)]
END CASE;

IF
IF expr1 THEN instruccion(es)
[ELSEIF expr2 THEN instruccion(es)] ...
[ELSE instruccion(es)]
END IF

ITERATE
ITERATE etiqueta

ITERATE solamente puede aparecer dentro de un LOOP, REPEAT y WHILE . Lo que
realmente significa es: "Haz el ciclo de Nuevo". Por ejemplo:

CREATE PROCEDURE doiterate(p1 INT)
BEGIN

ITERATE label1;

label1: LOOP
SET p1 = p1 + 1;
IF p1 < 10 THEN

END IF;
LEAVE label1;
END LOOP label1;
SET @x = p1;



END;

LEAVE
LEAVE etiqueta

Esta instrucción es utilizada para salir de alguna estructura de control. Puede ser usada
dentro de un BEGIN … END o dentro de algún ciclo.

LOOP
[etiqueta_inicio:] LOOP
instruccion(es)
END LOOP [etiqueta_fin]


LOOP implementa un ciclo simple, permitiendo que una instrucción o conjunto
de instrucciones se repitan. Las instrucciones dentro de este ciclo se repetirán hasta que
se ocasione alguna salida, lo cual se hace generalmente con una instrucción LEAVE.


Un ciclo LOOP puede ser etiquetado. etiqueta_fin no puede estar presente a
menos que etiqueta_inicio también lo está y, si ambos están presentes, deberán ser
iguales.

REPEAT
[etiqueta_inicio:] REPEAT
instruccion(es)
UNTIL condicion
END REPEAT [etiqueta_fin];


La instrucción o instrucciones dentro de un ciclo REPEAT se repetirán hasta que

la condicion sea verdadadera.


Un ciclo REPEAT puede ser etiquetado. etiqueta_fin no puede estar presente a
menos que etiqueta_inicio también lo está y, si ambos están presentes, deberán ser
iguales.

RETURN
RETURN expresión;

La instrucción RETURN se utiliza solamente dentro de una función. Al ejecutarse,
terminará por completo la función dentro de la que se encuentra.

WHILE
[etiqueta_inicio:] WHILE condición DO

instruccion(es)

END WHILE [etiqueta_fin]


La instrucción o instrucciones dentro de un WHILE serán repetidas mientras la

condición sea verdadera.


Un ciclo WHILE puede ser etiquetado. etiqueta_fin no puede estar presente a
menos que etiqueta_inicio también lo está y, si ambos están presentes, deberán ser
iguales.

Declaraciones
En una declaración se pueden crear:


• Variables locales
• Condiciones
• Cursores
• Manejadores


DECLARE
predeterminado ];

nombre_de_variable

[,

nombre_de_variable…]

TIPO

[valor


DECLARE nombre_de_condición CONDITION FOR condición

condicion: {SQLSTATE [VALOR] sqlstate_value | mysql_errno}

DECLARE nombre_del_cursor CURSOR FOR instrucción_select

DECLARE handler_type
HANDLER FOR handler_condition [, handler_condition] …
instruccion

handler_type: {CONTINUE | EXIT}
handler_condition:
{
SQLSTATE[VALUE] sqlstate_value
| mysql_errno
| condition_name
| SQLWARNING
| NOT FOUND
| SQLEXCEPTION
}


La declaración de una variable local, una condición, un cursor o un manejador
solamente puede aparecer al principio de un bloque BEGIN … END. Si se necesitan
hacer diferentes declaraciones, éstas deben hacerse en el siguiente orden:


• Declaración de variables y condiciones
• Declaración de cursores
• Declaración
  • Links de descarga
http://lwp-l.com/pdf17896

Comentarios de: Procedimientos y Funciones - MySQL básico (0)


No hay comentarios
 

Comentar...

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad