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
Source : https://how2geek.net
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.
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.