Fonction SQL ORACLE – NVL()

La fonction NVL remplace une valeur nulle avec une valeur non nulle. NVL prend deux paramètres:

NVL(arg1, arg2)

La fonction NVL retourne arg2 si arg1 est nulle, sinon la fonction retourne arg1. Les paramètres utilisés par NVL peuvent être de tout type de données.

Exemple:

Nous voulons afficher le revenu total des salaries de la table EMPLOYEES (schéma HR), qui ont le prénom qui commence par D:

SELECT
FIRST_NAME PRENOM, LAST_NAME NOM, SALARY SALAIRE, COMMISSION_PCT PRIME,
SALARY + (SALARY * COMMISSION_PCT) REVENU
FROM EMPLOYEES WHERE FIRST_NAME LIKE 'D%';


PRENOM      NOM        SALAIRE   PRIME    REVENU  
----------- ---------- --------- -------- --------
Donald      OConnell   2600                       
Douglas     Grant      2600                       
David       Austin     4800                       
Diana       Lorentz    4200                       
Daniel      Faviet     9000                       
Den         Raphaely   11000                      
David       Bernstein  9500      0,25     11875   
Danielle    Greene     9500      0,15     10925   
David       Lee        6800      0,1      7480   

Vous pouvez voir que le REVENU est nulLe pour ceux qui n’ont pas de prime. Pour afficher les revenus de tout le monde, nous allons utiliser la fonction NVL sur la colonne COMMISSION_PCT pour la mettre à O si elle est nulle. Le résultat de la requête avec NVL est :

SELECT
FIRST_NAME PRENOM, LAST_NAME NOM, SALARY SALAIRE, COMMISSION_PCT PRIME,
SALARY + (SALARY * NVL(COMMISSION_PCT, 0)) REVENU
FROM EMPLOYEES WHERE FIRST_NAME LIKE 'D%';


PRENOM      NOM        SALAIRE   PRIME    REVENU  
----------- ---------- --------- -------- --------
Donald      OConnell   2600               2600    
Douglas     Grant      2600               2600    
David       Austin     4800               4800    
Diana       Lorentz    4200               4200    
Daniel      Faviet     9000               9000    
Den         Raphaely   11000              11000   
David       Bernstein  9500      0,25     11875   
Danielle    Greene     9500      0,15     10925   
David       Lee        6800      0,1      7480

2 commentaires

  • Sergio

    A noter que cette fonction ne permet pas, si la requête ne retourne aucune ligne, de générer une ligne par défaut : elle ne joue que sur les colonnes nulles de lignes existantes.

    • admin

      Oui tout à fait, cette fonction ne retourne un résultat que si la requête elle même retourne une ou plusieurs lignes.
      Merci pour la précision.

Laisser un commentaire