PL / SQL - Variables

Dans ce chapitre, nous aborderons les variables dans Pl / SQL. Une variable n'est rien d'autre qu'un nom donné à une zone de stockage que nos programmes peuvent manipuler. Chaque variable dans PL / SQL a un type de données spécifique, qui détermine la taille et la disposition de la mémoire de la variable; la plage de valeurs pouvant être stockées dans cette mémoire et l'ensemble des opérations pouvant être appliquées à la variable.

Le nom d'une variable PL / SQL se compose d'une lettre éventuellement suivie de plusieurs lettres, chiffres, signes dollar, traits de soulignement et signes numériques et ne doit pas dépasser 30 caractères. Par défaut, les noms de variables ne sont pas sensibles à la casse. Vous ne pouvez pas utiliser un mot clé PL / SQL réservé comme nom de variable.

Le langage de programmation PL / SQL permet de définir différents types de variables, tels que les types de données date / heure, les enregistrements, les collections, etc. que nous aborderons dans les chapitres suivants. Pour ce chapitre, étudions uniquement les types de variables de base.

Déclaration de variable en PL / SQL

Les variables PL / SQL doivent être déclarées dans la section déclaration ou dans un package en tant que variable globale. Lorsque vous déclarez une variable, PL / SQL alloue de la mémoire pour la valeur de la variable et l'emplacement de stockage est identifié par le nom de la variable.

La syntaxe pour déclarer une variable est -

variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]

Où, nom_variable est un identifiant valide en PL / SQL, le type de données doit être un type de données PL / SQL valide ou tout type de données défini par l'utilisateur dont nous avons déjà parlé dans le dernier chapitre. Certaines déclarations de variables valides ainsi que leur définition sont présentées ci-dessous -

sales number(10, 2); 
pi CONSTANT double precision := 3.1415; 
name varchar2(25); 
address varchar2(100);

Lorsque vous indiquez une taille, une échelle ou une limite de précision avec le type de données, cela s'appelle un constrained declaration. Les déclarations contraintes nécessitent moins de mémoire que les déclarations non contraintes. Par exemple -

sales number(10, 2); 
name varchar2(25); 
address varchar2(100);

Initialisation des variables dans PL / SQL

Chaque fois que vous déclarez une variable, PL / SQL lui attribue une valeur par défaut NULL. Si vous souhaitez initialiser une variable avec une valeur autre que la valeur NULL, vous pouvez le faire lors de la déclaration, en utilisant l'une des méthodes suivantes:

  • le DEFAULT mot-clé

  • le assignment opérateur

Par exemple -

counter binary_integer := 0; 
greetings varchar2(20) DEFAULT 'Have a Good Day';

Vous pouvez également spécifier qu'une variable ne doit pas avoir NULL valeur en utilisant le NOT NULLcontrainte. Si vous utilisez la contrainte NOT NULL, vous devez explicitement affecter une valeur initiale à cette variable.

C'est une bonne pratique de programmation d'initialiser correctement les variables, sinon les programmes produiraient parfois des résultats inattendus. Essayez l'exemple suivant qui utilise différents types 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; 
/

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Value of c: 30 
Value of f: 23.333333333333333333  

PL/SQL procedure successfully completed.

Portée variable en PL / SQL

PL / SQL permet l'imbrication de blocs, c'est-à-dire que chaque bloc de programme peut contenir un autre bloc interne. Si une variable est déclarée dans un bloc interne, elle n'est pas accessible au bloc externe. Cependant, si une variable est déclarée et accessible à un bloc externe, elle est également accessible à tous les blocs internes imbriqués. Il existe deux types de portée variable -

  • Local variables - Variables déclarées dans un bloc interne et non accessibles aux blocs externes.

  • Global variables - Variables déclarées dans le bloc le plus à l'extérieur ou dans un package.

L'exemple suivant montre l'utilisation de Local et Global variables sous sa forme 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; 
/

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Outer Variable num1: 95 
Outer Variable num2: 85 
Inner Variable num1: 195 
Inner Variable num2: 185  

PL/SQL procedure successfully completed.

Attribution de résultats de requête SQL à des variables PL / SQL

Vous pouvez utiliser le SELECT INTOinstruction SQL pour affecter des valeurs aux variables PL / SQL. Pour chaque élément duSELECT list, il doit y avoir une variable correspondante compatible avec le type dans le INTO list. L'exemple suivant illustre le concept. Créons une table nommée CLIENTS -

(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

Insérons maintenant quelques valeurs dans le tableau -

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 );

Le programme suivant affecte les valeurs du tableau ci-dessus aux variables PL / SQL à l'aide du 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; 
/

Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -

Customer Ramesh from Ahmedabad earns 2000  

PL/SQL procedure completed successfully