Você está na página 1de 2

Declarar variables locales con DECLARE

DECLARE var_name[,...] type [DEFAULT value]

Este comando se usa para declarar variables locales. Para proporcionar un


valor por defecto para la variable, incluya una clusula DEFAULT . El valor
puede especificarse como expresin, no necesita ser una constante. Si la
clusula DEFAULT no est presente, el valor inicial es NULL.

La visibilidad de una variable local es dentro del bloque BEGIN ... END donde
est declarado. Puede usarse en bloques anidados excepto aqullos que
declaren una variable con el mismo nombre.

Sentencia SET para variables


SET var_name = expr [, var_name = expr] ...

El comando SET en procedimientos almacenados es una versin extendida del


comando general SET. Las variables referenciadas pueden ser las declaradas
dentro de una rutina, o variables de servidor globales.
El comando SET en procedimientos almacenados se implementa como parte de la
sintaxis SET pre-existente. Esto permite una sintaxis extendida de SET a=x,
b=y, ... donde distintos tipos de variables (variables declaradas local y
globalmente y variables de sesin del servidor) pueden mezclarse. Esto permite
combinaciones de variables locales y algunas opciones que tienen sentido slo
para variables de sistema; en tal caso, las opciones se reconocen pero se ignoran.

19.2.9.3. La sentencia SELECT ... INTO


SELECT col_name[,...] INTO var_name[,...] table_expr

Esta sintaxis SELECT almacena columnas seleccionadas directamente en


variables. Por lo tanto, slo un registro puede retornarse.
SELECT id,data INTO x,y FROM test.t1 LIMIT 1;

Sentencia SELECT INTO


La sentencia SELECT INTO produce una tabla de resultados que consta
de como mximo una fila y asigna los valores de dicha fila a las variables
del lenguaje principal.

Sentencia DECLARE CURSOR


La sentencia DECLARE define un cursor.

Invocacin
Aunque un recurso SQL interactivo pueda proporcionar una interfaz que
d la apariencia de ejecucin interactiva, esta sentencia slo puede
incorporarse dentro de un programa de aplicacin. No se trata de una
sentencia ejecutable y no puede prepararse de forma dinmica. Cuando
se invoca utilizando el procesador de lnea de mandatos, se pueden
especificar opciones adicionales. Para obtener ms informacin, consulte
la seccin sobre utilizacin de sentencias de SQL y XQuery de lnea de
mandatos.
SET [GLOBAL | SESSION] sql_variable=expression,
[[GLOBAL | SESSION] sql_variable=expression] ...

SET activa varias opciones que afectan al funcionamiento del servidor y el cliente.
Los siguientes ejemplos muestran las diferentes sintaxis que se pueden usar para
modificar variables:
En versiones antiguas de MySQL est permitido usar la sintaxis SET OPTION, pero
esto est desaconsejado ahora.
En MySQL 4.0.3 se han aadido las opciones GLOBAL y SESSION y acceso a las
variables de arranque ms importantes.
LOCAL se puede usar como sinnimo de SESSION.
Si se modifican varias variables en la misma lnea de comando, se usa el ltimo
modo GLOBAL | SESSION.

Você também pode gostar