9. Fonctions et opérateurs

9.1. Opérateurs logiques
9.2. Opérateurs de comparaison
9.3. Fonctions et opérateurs mathématiques
9.4. Fonctions et opérateurs de chaînes
9.5. Fonctions et opérateurs de chaînes binaires
9.6. Fonctions et opérateurs pour les chaînes de bits
9.7. Correspondance de modèles
9.8. Fonctions de formatage des types de données
9.9. Fonctions et opérateurs pour date/heure
9.10. Fonctions et opérateurs géométriques
9.11. Fonctions et opérateurs pour le type des adresses réseau
9.12. Fonctions de manipulation de séquence
9.13. Expressions conditionnelles
9.14. Fonctions et opérateurs sur les tableaux
9.15. Fonctions d'agrégat
9.16. Expressions de sous-expressions
9.17. Comparaisons de lignes et de tableaux
9.18. Fonctions renvoyant des ensembles
9.19. Fonctions d'information sur le système
9.20. Fonctions d'administration système

PostgreSQL™ fournit un grand nombre de fonctions et d'opérateurs pour les types de données intégrés. Les utilisateurs peuvent aussi définir leurs propres fonctions et opérateurs comme décrit dans la Partie V, « Programmation serveur ». Les commandes \df et \do de psql sont utilisées pour afficher respectivement la liste de toutes les fonctions et de tous les opérateurs.

Si la portabilité vous concerne, prenez note que la plupart des fonctions et opérateurs décrits dans ce chapitre, à l'exception des opérateurs arithmétiques et logiques les plus triviaux et de quelques fonctions spécifiquement indiquées, ne font pas partie du standard SQL. Quelques-unes des fonctionnalités étendues sont présentes dans d'autres systèmes de gestion de bases de données SQL et dans la plupart des cas, ces fonctionnalités sont compatibles et cohérentes à de nombreuses implémentations. Ce chapitre n'est pas exhaustif ; des fonctions supplémentaires apparaissent dans les sections adéquates du manuel.

9.1. Opérateurs logiques

Voici la liste des opérateurs logiques habituels :

AND
OR
NOT

SQL utilise une logique booléenne à trois valeurs et où la valeur NULL représente « inconnu ». Observez les tables de vérité suivantes :

a b a AND b a OR b
TRUE TRUE TRUE TRUE
TRUE FALSE FALSE TRUE
TRUE NULL NULL TRUE
FALSE FALSE FALSE FALSE
FALSE NULL FALSE NULL
NULL NULL NULL NULL
a NOT a
TRUE FALSE
FALSE TRUE
NULL NULL

Les opérateurs AND et OR sont commutatifs, c'est-à-dire que l'échange des opérandes gauche et droit n'affecte pas le résultat. Voir la Section 4.2.12, « Règles d'évaluation des expressions » pour plus d'informations sur l'ordre d'évaluation des sous-expressions.