PL / SQL - Chaînes

La chaîne en PL / SQL est en fait une séquence de caractères avec une spécification de taille facultative. Les caractères peuvent être numériques, lettres, blancs, caractères spéciaux ou une combinaison de tous. PL / SQL propose trois types de chaînes -

  • Fixed-length strings- Dans de telles chaînes, les programmeurs spécifient la longueur lors de la déclaration de la chaîne. La chaîne est complétée à droite avec des espaces à la longueur ainsi spécifiée.

  • Variable-length strings - Dans de telles chaînes, une longueur maximale jusqu'à 32 767, pour la chaîne est spécifiée et aucun remplissage n'a lieu.

  • Character large objects (CLOBs) - Ce sont des chaînes de longueur variable pouvant aller jusqu'à 128 téraoctets.

Les chaînes PL / SQL peuvent être des variables ou des littéraux. Un littéral de chaîne est placé entre guillemets. Par exemple,

'This is a string literal.' Or 'hello world'

Pour inclure un guillemet simple dans une chaîne littérale, vous devez taper deux guillemets simples l'un à côté de l'autre. Par exemple,

'this isn''t what it looks like'

Déclaration de variables de chaîne

La base de données Oracle fournit de nombreux types de données de type chaîne, tels que CHAR, NCHAR, VARCHAR2, NVARCHAR2, CLOB et NCLOB. Les types de données précédés d'un'N' sont 'national character set' les types de données, qui stockent les données de caractères Unicode.

Si vous devez déclarer une chaîne de longueur variable, vous devez fournir la longueur maximale de cette chaîne. Par exemple, le type de données VARCHAR2. L'exemple suivant illustre la déclaration et l'utilisation de certaines variables de chaîne -

DECLARE 
   name varchar2(20); 
   company varchar2(30); 
   introduction clob; 
   choice char(1); 
BEGIN 
   name := 'John Smith'; 
   company := 'Infotech'; 
   introduction := ' Hello! I''m John Smith from Infotech.'; 
   choice := 'y'; 
   IF choice = 'y' THEN 
      dbms_output.put_line(name); 
      dbms_output.put_line(company); 
      dbms_output.put_line(introduction); 
   END IF; 
END; 
/

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

John Smith 
Infotech
Hello! I'm John Smith from Infotech.  

PL/SQL procedure successfully completed

Pour déclarer une chaîne de longueur fixe, utilisez le type de données CHAR. Ici, il n'est pas nécessaire de spécifier une longueur maximale pour une variable de longueur fixe. Si vous omettez la contrainte de longueur, Oracle Database utilise automatiquement une longueur maximale requise. Les deux déclarations suivantes sont identiques -

red_flag CHAR(1) := 'Y'; 
 red_flag CHAR   := 'Y';

Fonctions et opérateurs de chaînes PL / SQL

PL / SQL propose l'opérateur de concaténation (||)pour joindre deux chaînes. Le tableau suivant fournit les fonctions de chaîne fournies par PL / SQL -

S. Non Fonction et objectif
1

ASCII(x);

Renvoie la valeur ASCII du caractère x.

2

CHR(x);

Renvoie le caractère avec la valeur ASCII de x.

3

CONCAT(x, y);

Concatène les chaînes x et y et renvoie la chaîne ajoutée.

4

INITCAP(x);

Convertit la lettre initiale de chaque mot en x en majuscule et renvoie cette chaîne.

5

INSTR(x, find_string [, start] [, occurrence]);

Recherches pour find_string en x et renvoie la position à laquelle il se produit.

6

INSTRB(x);

Renvoie l'emplacement d'une chaîne dans une autre chaîne, mais renvoie la valeur en octets.

sept

LENGTH(x);

Renvoie le nombre de caractères de x.

8

LENGTHB(x);

Renvoie la longueur d'une chaîne de caractères en octets pour un jeu de caractères à un octet.

9

LOWER(x);

Convertit les lettres en x en minuscules et renvoie cette chaîne.

dix

LPAD(x, width [, pad_string]) ;

Tampons x avec des espaces à gauche, pour amener la longueur totale de la chaîne à la largeur des caractères.

11

LTRIM(x [, trim_string]);

Coupe les caractères à gauche de x.

12

NANVL(x, value);

Renvoie la valeur si x correspond à la valeur spéciale NaN (pas un nombre), sinon x est retourné.

13

NLS_INITCAP(x);

Identique à la fonction INITCAP, sauf qu'elle peut utiliser une méthode de tri différente de celle spécifiée par NLSSORT.

14

NLS_LOWER(x) ;

Identique à la fonction LOWER, sauf qu'elle peut utiliser une méthode de tri différente, comme spécifié par NLSSORT.

15

NLS_UPPER(x);

Identique à la fonction UPPER, sauf qu'elle peut utiliser une méthode de tri différente, comme spécifié par NLSSORT.

16

NLSSORT(x);

Modifie la méthode de tri des caractères. Doit être spécifié avant toute fonction NLS; sinon, le tri par défaut sera utilisé.

17

NVL(x, value);

Renvoie la valeur si xest nul; sinon, x est renvoyé.

18

NVL2(x, value1, value2);

Renvoie valeur1 si x n'est pas nul; si x est nul, valeur2 est renvoyée.

19

REPLACE(x, search_string, replace_string);

Recherches x pour search_string et le remplace par replace_string.

20

RPAD(x, width [, pad_string]);

Tampons x à droite.

21

RTRIM(x [, trim_string]);

Trims x de la droite.

22

SOUNDEX(x) ;

Renvoie une chaîne contenant la représentation phonétique de x.

23

SUBSTR(x, start [, length]);

Renvoie une sous-chaîne de xqui commence à la position spécifiée par start. Une longueur facultative pour la sous-chaîne peut être fournie.

24

SUBSTRB(x);

Identique à SUBSTR sauf que les paramètres sont exprimés en octets au lieu de caractères pour les systèmes de caractères à un octet.

25

TRIM([trim_char FROM) x);

Coupe les caractères à gauche et à droite de x.

26

UPPER(x);

Convertit les lettres en x en majuscules et renvoie cette chaîne.

Travaillons maintenant sur quelques exemples pour comprendre le concept -

Exemple 1

DECLARE 
   greetings varchar2(11) := 'hello world'; 
BEGIN 
   dbms_output.put_line(UPPER(greetings)); 
    
   dbms_output.put_line(LOWER(greetings)); 
    
   dbms_output.put_line(INITCAP(greetings)); 
    
   /* retrieve the first character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, 1, 1)); 
    
   /* retrieve the last character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, -1, 1)); 
    
   /* retrieve five characters,  
      starting from the seventh position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 7, 5)); 
    
   /* retrieve the remainder of the string, 
      starting from the second position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 2)); 
     
   /* find the location of the first "e" */ 
   dbms_output.put_line ( INSTR (greetings, 'e')); 
END; 
/

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

HELLO WORLD 
hello world 
Hello World 
h 
d 
World 
ello World 
2  

PL/SQL procedure successfully completed.

Exemple 2

DECLARE 
   greetings varchar2(30) := '......Hello World.....'; 
BEGIN 
   dbms_output.put_line(RTRIM(greetings,'.')); 
   dbms_output.put_line(LTRIM(greetings, '.')); 
   dbms_output.put_line(TRIM( '.' from greetings)); 
END; 
/

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

......Hello World  
Hello World..... 
Hello World  

PL/SQL procedure successfully completed.