PostgreSQL - Clause WHERE

La clause PostgreSQL WHERE est utilisée pour spécifier une condition lors de la récupération des données à partir d'une seule table ou lors de la jonction avec plusieurs tables.

Si la condition donnée est satisfaite, alors seulement elle renvoie une valeur spécifique de la table. Vous pouvez filtrer les lignes que vous ne souhaitez pas inclure dans le jeu de résultats à l'aide de la clause WHERE.

La clause WHERE est non seulement utilisée dans l'instruction SELECT, mais elle est également utilisée dans l'instruction UPDATE, DELETE, etc., que nous examinerons dans les chapitres suivants.

Syntaxe

La syntaxe de base de l'instruction SELECT avec la clause WHERE est la suivante -

SELECT column1, column2, columnN
FROM table_name
WHERE [search_condition]

Vous pouvez spécifier un critère_recherche en utilisant la comparaison ou les opérateurs logiques. comme>, <, =, LIKE, NOT, etc. Les exemples suivants clarifieraient ce concept.

Exemple

Considérez la table COMPANY ayant des enregistrements comme suit -

testdb# select * from COMPANY;
 id | name  | age | address   | salary
----+-------+-----+-----------+--------
  1 | Paul  |  32 | California|  20000
  2 | Allen |  25 | Texas     |  15000
  3 | Teddy |  23 | Norway    |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas     |  85000
  6 | Kim   |  22 | South-Hall|  45000
  7 | James |  24 | Houston   |  10000
(7 rows)

Voici des exemples simples montrant l'utilisation des opérateurs logiques PostgreSQL. L'instruction SELECT suivante listera tous les enregistrements où AGE est supérieur ou égal à 25AND le salaire est supérieur ou égal à 65000,00 -

testdb=# SELECT * FROM COMPANY WHERE AGE >= 25 AND SALARY >= 65000;

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age |  address   | salary
----+-------+-----+------------+--------
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(2 rows)

L'instruction SELECT suivante répertorie tous les enregistrements où AGE est supérieur ou égal à 25 OR le salaire est supérieur ou égal à 65000,00 -

testdb=# SELECT * FROM COMPANY WHERE AGE >= 25 OR SALARY >= 65000;

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age | address     | salary
----+-------+-----+-------------+--------
  1 | Paul  |  32 | California  |  20000
  2 | Allen |  25 | Texas       |  15000
  4 | Mark  |  25 | Rich-Mond   |  65000
  5 | David |  27 | Texas       |  85000
(4 rows)

L'instruction SELECT suivante répertorie tous les enregistrements où AGE n'est pas NULL, ce qui signifie tous les enregistrements, car aucun des enregistrements n'a AGE égal à NULL -

testdb=#  SELECT * FROM COMPANY WHERE AGE IS NOT NULL;

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age | address    | salary
 ----+-------+-----+------------+--------
   1 | Paul  |  32 | California |  20000
   2 | Allen |  25 | Texas      |  15000
   3 | Teddy |  23 | Norway     |  20000
   4 | Mark  |  25 | Rich-Mond  |  65000
   5 | David |  27 | Texas      |  85000
   6 | Kim   |  22 | South-Hall |  45000
   7 | James |  24 | Houston    |  10000
(7 rows)

L'instruction SELECT suivante répertorie tous les enregistrements où NAME commence par «Pa», peu importe ce qui vient après «Pa».

testdb=# SELECT * FROM COMPANY WHERE NAME LIKE 'Pa%';

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name | age |address    | salary
----+------+-----+-----------+--------
  1 | Paul |  32 | California|  20000

L'instruction SELECT suivante répertorie tous les enregistrements où la valeur AGE est 25 ou 27 -

testdb=# SELECT * FROM COMPANY WHERE AGE IN ( 25, 27 );

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  2 | Allen |  25 | Texas      |  15000
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(3 rows)

L'instruction SELECT suivante répertorie tous les enregistrements où la valeur AGE n'est ni 25 ni 27 -

testdb=# SELECT * FROM COMPANY WHERE AGE NOT IN ( 25, 27 );

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  1 | Paul  |  32 | California |  20000
  3 | Teddy |  23 | Norway     |  20000
  6 | Kim   |  22 | South-Hall |  45000
  7 | James |  24 | Houston    |  10000
(4 rows)

L'instruction SELECT suivante répertorie tous les enregistrements où la valeur AGE est comprise entre 25 ET 27 -

testdb=# SELECT * FROM COMPANY WHERE AGE BETWEEN 25 AND 27;

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  2 | Allen |  25 | Texas      |  15000
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
(3 rows)

L'instruction SELECT suivante utilise la sous-requête SQL où la sous-requête trouve tous les enregistrements avec le champ AGE ayant SALARY> 65000 et les versions ultérieures La clause WHERE est utilisée avec l'opérateur EXISTS pour répertorier tous les enregistrements où AGE de la requête externe existe dans le résultat renvoyé par sous-requête -

testdb=# SELECT AGE FROM COMPANY
        WHERE EXISTS (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

age
-----
  32
  25
  23
  25
  27
  22
  24
(7 rows)

L'instruction SELECT suivante utilise la sous-requête SQL où la sous-requête trouve tous les enregistrements avec le champ AGE ayant SALARY> 65000 et les versions ultérieures La clause WHERE est utilisée avec l'opérateur> pour répertorier tous les enregistrements où AGE de la requête externe est supérieur à l'âge en le résultat renvoyé par la sous-requête -

testdb=# SELECT * FROM COMPANY
        WHERE AGE > (SELECT AGE FROM COMPANY WHERE SALARY > 65000);

L'instruction PostgreSQL donnée ci-dessus produira le résultat suivant -

id | name | age | address    | salary
----+------+-----+------------+--------
  1 | Paul |  32 | California |  20000