PL / SQL - Variables
En este capítulo, discutiremos Variables en Pl / SQL. Una variable no es más que un nombre que se le da a un área de almacenamiento que nuestros programas pueden manipular. Cada variable en PL / SQL tiene un tipo de datos específico, que determina el tamaño y el diseño de la memoria de la variable; el rango de valores que se pueden almacenar dentro de esa memoria y el conjunto de operaciones que se pueden aplicar a la variable.
El nombre de una variable PL / SQL consiste en una letra seguida opcionalmente de más letras, números, signos de dólar, guiones bajos y signos de números y no debe exceder los 30 caracteres. De forma predeterminada, los nombres de las variables no distinguen entre mayúsculas y minúsculas. No puede utilizar una palabra clave PL / SQL reservada como nombre de variable.
El lenguaje de programación PL / SQL permite definir varios tipos de variables, como tipos de datos de fecha y hora, registros, colecciones, etc., que trataremos en capítulos posteriores. Para este capítulo, estudiemos solo los tipos de variables básicas.
Declaración de variable en PL / SQL
Las variables PL / SQL deben declararse en la sección de declaración o en un paquete como una variable global. Cuando declara una variable, PL / SQL asigna memoria para el valor de la variable y la ubicación de almacenamiento se identifica mediante el nombre de la variable.
La sintaxis para declarar una variable es:
variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]
Donde, variable_name es un identificador válido en PL / SQL, el tipo de datos debe ser un tipo de datos PL / SQL válido o cualquier tipo de datos definido por el usuario que ya hemos discutido en el último capítulo. Algunas declaraciones de variables válidas junto con su definición se muestran a continuación:
sales number(10, 2);
pi CONSTANT double precision := 3.1415;
name varchar2(25);
address varchar2(100);
Cuando proporciona un límite de tamaño, escala o precisión con el tipo de datos, se denomina constrained declaration. Las declaraciones restringidas requieren menos memoria que las declaraciones no restringidas. Por ejemplo
sales number(10, 2);
name varchar2(25);
address varchar2(100);
Inicialización de variables en PL / SQL
Siempre que declara una variable, PL / SQL le asigna un valor predeterminado de NULL. Si desea inicializar una variable con un valor diferente al valor NULL, puede hacerlo durante la declaración, usando cualquiera de los siguientes:
los DEFAULT palabra clave
los assignment operador
Por ejemplo
counter binary_integer := 0;
greetings varchar2(20) DEFAULT 'Have a Good Day';
También puede especificar que una variable no debe tener un NULL valor usando el NOT NULLrestricción. Si usa la restricción NOT NULL, debe asignar explícitamente un valor inicial para esa variable.
Es una buena práctica de programación inicializar las variables correctamente; de lo contrario, a veces los programas producirían resultados inesperados. Pruebe el siguiente ejemplo que utiliza varios tipos de variables:
DECLARE
a integer := 10;
b integer := 20;
c integer;
f real;
BEGIN
c := a + b;
dbms_output.put_line('Value of c: ' || c);
f := 70.0/3.0;
dbms_output.put_line('Value of f: ' || f);
END;
/
Cuando se ejecuta el código anterior, produce el siguiente resultado:
Value of c: 30
Value of f: 23.333333333333333333
PL/SQL procedure successfully completed.
Alcance variable en PL / SQL
PL / SQL permite el anidamiento de bloques, es decir, cada bloque de programa puede contener otro bloque interno. Si una variable se declara dentro de un bloque interno, no es accesible para el bloque externo. Sin embargo, si una variable se declara y es accesible para un bloque externo, también es accesible para todos los bloques internos anidados. Hay dos tipos de alcance variable:
Local variables - Variables declaradas en un bloque interno y no accesibles a bloques externos.
Global variables - Variables declaradas en el bloque más externo o un paquete.
El siguiente ejemplo muestra el uso de Local y Global variables en su forma simple -
DECLARE
-- Global variables
num1 number := 95;
num2 number := 85;
BEGIN
dbms_output.put_line('Outer Variable num1: ' || num1);
dbms_output.put_line('Outer Variable num2: ' || num2);
DECLARE
-- Local variables
num1 number := 195;
num2 number := 185;
BEGIN
dbms_output.put_line('Inner Variable num1: ' || num1);
dbms_output.put_line('Inner Variable num2: ' || num2);
END;
END;
/
Cuando se ejecuta el código anterior, produce el siguiente resultado:
Outer Variable num1: 95
Outer Variable num2: 85
Inner Variable num1: 195
Inner Variable num2: 185
PL/SQL procedure successfully completed.
Asignar resultados de consultas SQL a variables PL / SQL
Puedes usar el SELECT INTOdeclaración de SQL para asignar valores a las variables PL / SQL. Para cada elemento de laSELECT list, debe haber una variable de tipo compatible correspondiente en el INTO list. El siguiente ejemplo ilustra el concepto. Creemos una tabla llamada CLIENTES -
(For SQL statements, please refer to the SQL tutorial)
CREATE TABLE CUSTOMERS(
ID INT NOT NULL,
NAME VARCHAR (20) NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR (25),
SALARY DECIMAL (18, 2),
PRIMARY KEY (ID)
);
Table Created
Insertemos ahora algunos valores en la tabla:
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (6, 'Komal', 22, 'MP', 4500.00 );
El siguiente programa asigna valores de la tabla anterior a variables PL / SQL usando el SELECT INTO clause de SQL -
DECLARE
c_id customers.id%type := 1;
c_name customers.name%type;
c_addr customers.address%type;
c_sal customers.salary%type;
BEGIN
SELECT name, address, salary INTO c_name, c_addr, c_sal
FROM customers
WHERE id = c_id;
dbms_output.put_line
('Customer ' ||c_name || ' from ' || c_addr || ' earns ' || c_sal);
END;
/
Cuando se ejecuta el código anterior, produce el siguiente resultado:
Customer Ramesh from Ahmedabad earns 2000
PL/SQL procedure completed successfully