Cour SQL 1

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 34

Cours SQL

Base du langage SQL et des bases de données

1/34
SQL SELECT
L’utilisation la plus courante de SQL consiste à lire des données issues de la base de données. Cela
s’effectue grâce à la commande SELECT, qui retourne des enregistrements dans un tableau de
résultat. Cette commande peut sélectionner une ou plusieurs colonnes d’une table.

Commande basique
L’utilisation basique de cette commande s’effectue de la manière suivante :

SELECT nom_du_champ
FROM nom_du_tableau

Cette requête va sélectionner (SELECT) le champ « nom_du_champ » provenant (FROM) du


tableau appelé « nom_du_tableau ».

Exemple
Imaginons une base de données appelée « client » qui contient des informations sur les clients d’une
entreprise.

Table « client » :

identifiant prenom nom ville


1 Pierre Dupond Paris
2 Sabrina Durand Nantes
3 Julien Martin Lyon
4 David Bernard Marseille
5 Marie Leroy Grenoble

Si l’ont veut avoir la liste de toutes les villes des clients, il suffit d’effectuer la requête suivante :

SELECT ville
FROM client

Résultat :

ville
Paris
Nantes
Lyon
Marseille
Grenoble

2/34
Obtenir plusieurs colonnes
Avec la même table client il est possible de lire plusieurs colonnes à la fois. Il suffit tout simplement
de séparer les noms des champs souhaités par une virgule. Pour obtenir les prénoms et les noms
des clients il faut alors faire la requête suivante:

SELECT prenom, nom


FROM client

Résultat :

prenom nom
Pierre Dupond
Sabrina Durand
Julien Martin
David Bernard
Marie Leroy

Obtenir toutes les colonnes d’un tableau


Il est possible de retourner automatiquement toutes les colonnes d’un tableau sans avoir à connaître
le nom de toutes les colonnes. Au lieu de lister toutes les colonnes, il faut simplement utiliser le
caractère « * » (étoile). C’est un joker qui permet de sélectionner toutes les colonnes. Il s’utilise de la
manière suivante :

SELECT * FROM client

Cette requête retourne exactement les mêmes colonnes qu’il y a dans la base de données. Dans
notre cas, le résultat sera donc :

identifiant prenom nom ville


1 Pierre Dupond Paris
2 Sabrina Durand Nantes
3 Julien Martin Lyon
4 David Bernard Marseille
5 Marie Leroy Grenoble

Il y a des avantages et des inconvénient à l’utiliser. Pour en savoir plus sur le sujet il est recommandé
de lire l’article avantage et inconvénient du sélecteur étoile.

Cours avancé : ordre des commandes du SELECT


Cette commande SQL est relativement commune car il est très fréquent de devoir lire les données
issues d’une base de données. Il existe plusieurs commandes qui permettent de mieux gérer les
données que l’ont souhaite lire. Voici un petit aperçu des fonctionnalités possibles qui sont abordées
sur le reste du site:

3/34
• Joindre un autre tableau aux résultats
• Filtrer pour ne sélectionner que certains enregistrements
• Classer les résultats
• Grouper les résultats pour faire uniquement des statistiques (note moyenne, prix le plus élevé
…)
Un requête SELECT peut devenir assez longue. Juste à titre informatif, voici une requête SELECT
qui possède presque toutes les commandes possibles :

SELECT *
FROM table
WHERE condition
GROUP BY expression
HAVING condition
{ UNION | INTERSECT | EXCEPT }
ORDER BY expression
LIMIT count
OFFSET start

A noter : cette requête imaginaire sert principale d’aide-mémoire pour savoir dans quel ordre sont
utilisé chacun des commandes au sein d’une requête SELECT.

4/34
SQL DISTINCT
L’utilisation de la commande SELECT en SQL permet de lire toutes les données d’une ou plusieurs
colonnes. Cette commande peut potentiellement afficher des lignes en doubles. Pour éviter des
redondances dans les résultats il faut simplement ajouter DISTINCT après le mot SELECT.

Commande basique
L’utilisation basique de cette commande consiste alors à effectuer la requête suivante :

SELECT DISTINCT ma_colonne


FROM nom_du_tableau

Cette requête sélectionne le champ « ma_colonne » de la table « nom_du_tableau » en évitant de


retourner des doublons.

Exemple
Prenons le cas concret d’une table « client » qui contient des noms et prénoms :

identifiant prenom nom


1 Pierre Dupond
2 Sabrina Bernard
3 David Durand
4 Pierre Leroy
5 Marie Leroy

En utilisant seulement SELECT tous les noms sont retournés, or la table contient plusieurs fois le
même prénom (cf. Pierre). Pour sélectionner uniquement les prénoms uniques il faut utiliser la
requête suivante :

SELECT DISTINCT prenom


FROM client

Résultat :

prenom
Pierre
Sabrina
David
Marie

Intérêt
L’utilisation de la commande DISTINCT est très pratique pour éviter les résultats en doubles.
Cependant, pour optimiser les performances il est préférable d’utiliser la commande SQL GROUP BY
lorsque c’est possible.

5/34
SQL AS (alias)
Dans le langage SQL il est possible d’utiliser des alias pour renommer temporairement une colonne
ou une table dans une requête. Cette astuce est particulièrement utile pour faciliter la lecture des
requêtes.

Alias sur une table


Permet d’attribuer un autre nom à une table dans une requête SQL. Cela peut aider à avoir des
noms plus court, plus simple et plus facilement compréhensible. Ceci est particulièrement vrai
lorsqu’il y a des jointures.

Syntaxe
Alias sur une colonne
La syntaxe pour renommer une colonne de colonne1 à c1 est la suivante :

SELECT colonne1 AS c1, colonne2


FROM `table`

Cette syntaxe peut également s’afficher de la façon suivante :

SELECT colonne1 c1, colonne2


FROM `table`

A noter : à choisir il est préférable d’utiliser la commande « AS » pour que ce soit plus explicite (plus
simple à lire qu’un simple espace), d’autant plus que c’est recommandé dans le standard ISO pour
concevoir une requête SQL.

Alias sur une table


La syntaxe pour renommer une table dans une requête est la suivante :

SELECT *
FROM `nom_table` AS t1

Cette requête peut également s’écrire de la façon suivante :

SELECT *
FROM `table`t1

SQL WHERE
La commande WHERE dans une requête SQL permet d’extraire les lignes d’une base de données
qui respectent une condition. Cela permet d’obtenir uniquement les informations désirées.

Syntaxe
La commande WHERE s’utilise en complément à une requête utilisant SELECT. La façon la plus
simple de l’utiliser est la suivante :
6/34 sql.sh
SELECT nom_colonnes
FROM nom_table
WHERE condition

Exemple
Imaginons une base de données appelée « client » qui contient le nom des clients, le nombre de
commandes qu’ils ont effectués et leur ville :

id nom nbr_commande ville


1 Paul 3 paris
2 Maurice 0 rennes
3 Joséphine 1 toulouse
4 Gérard 7 paris

Pour obtenir seulement la liste des clients qui habitent à Paris, il faut effectuer la requête suivante :

SELECT *
FROM client
WHERE ville = 'paris'

Résultat :

id nom nbr_commande nbr_commande


1 Paul 3 paris
4 Gérard 7 paris

Opérateurs de comparaisons
Il existe plusieurs opérateurs de comparaisons. La liste ci-jointe présente quelques uns des
opérateurs les plus couramment utilisés.
Opérateur Description
= Égale
<> Pas égale
!= Pas égale
> Supérieur à
< Inférieur à
>= Supérieur ou égale à
<= Inférieur ou égale à
IN Liste de plusieurs valeurs possibles
BETWEEN Valeur comprise dans un intervalle donnée (utile pour les nombres ou dates)
LIKE Recherche en spécifiant le début, milieu ou fin d'un mot.

7/34 sql.sh
SQL AND & OR
Une requête SQL peut être restreinte à l’aide de la condition WHERE. Les opérateurs logiques AND
et OR peuvent être utilisées au sein de la commande WHERE pour combiner des conditions.

Syntaxe d’utilisation des opérateurs AND et OR


Les opérateurs sont à ajoutés dans la condition WHERE. Ils peuvent être combinés à l’infini pour
filtrer les données comme souhaités.

L’opérateur AND permet de s’assurer que la condition1 ET la condition2 sont vrai :

SELECT nom_colonnes
FROM nom_table
WHERE condition1 AND condition2

L’opérateur OR vérifie quant à lui que la condition1 OU la condition2 est vrai :

SELECT nom_colonnes FROM nom_table


WHERE condition1 OR condition2

Ces opérateurs peuvent être combinés à l’infini et mélangés. L’exemple ci-dessous filtre les résultats
de la table « nom_table » si condition1 ET condition2 OU condition3 est vrai :

SELECT nom_colonnes FROM nom_table


WHERE condition1 AND (condition2 OR condition3)

Attention : il faut penser à utiliser des parenthèses lorsque c’est nécessaire. Cela permet d’éviter les
erreurs car et ça améliore la lecture d’une requête par un humain.

Exemple de données
Pour illustrer les prochaines commandes, nous allons considérer la table « produit » suivante :

id nom categorie stock prix


1 ordinateur informatique 5 950
2 clavier informatique 32 35
3 souris informatique 16 30
4 crayon fourniture 147 2

Opérateur AND
L’opérateur AND permet de joindre plusieurs conditions dans une requête. En gardant la même table
que précédemment, pour filtrer uniquement les produits informatique qui sont presque en rupture de
stock (moins de 20 produits disponible) il faut exécuter la requête suivante :

SELECT * FROM produit


WHERE categorie = 'informatique' AND stock < 20

8/34 sql.sh
Résultat :

id nom categorie stock prix


1 ordinateur informatique 5 950
3 souris informatique 16 30

Opérateur OR
Pour filtrer les données pour avoir uniquement les données sur les produits « ordinateur » ou «
clavier » il faut effectuer la recherche suivante :

SELECT * FROM produit


WHERE nom = 'ordinateur' OR nom = 'clavier'

Résultats :

id nom categorie stock prix


1 ordinateur informatique 5 950
2 clavier informatique 32 35

Combiner AND et OR
Il ne faut pas oublier que les opérateurs peuvent être combinés pour effectuer de puissantes
recherche. Il est possible de filtrer les produits « informatique » avec un stock inférieur à 20 et les
produits « fourniture » avec un stock inférieur à 200 avec la recherche suivante :

SELECT * FROM produit


WHERE ( categorie = 'informatique' AND stock < 20 )
OR ( categorie = 'fourniture' AND stock < 200 )

Résultats :

id nom categorie stock prix


1 ordinateur informatique 5 950
2 clavier informatique 32 35
4 crayon fourniture 147 2

9/34 sql.sh
SQL IN
L’opérateur logique IN dans SQL s’utilise avec la commande WHERE pour vérifier si une colonne est
égale à une des valeurs comprise dans set de valeurs déterminés. C’est une méthode simple pour
vérifier si une colonne est égale à une valeur OU une autre valeur OU une autre valeur et ainsi de
suite, sans avoir à utiliser de multiple fois l’opérateur OR.

Syntaxe
Pour chercher toutes les lignes où la colonne « nom_colonne » est égale à ‘valeur 1′ OU ‘valeur 2′ ou
‘valeur 3′, il est possible d’utiliser la syntaxe suivante :

SELECT nom_colonne
FROM table
WHERE nom_colonne IN ( valeur1, valeur2, valeur3, ... )

A savoir : entre les parenthèses il n’y a pas de limite du nombre d’arguments. Il est possible
d’ajouter encore d’autres valeurs.

Cette syntaxe peut être associée à l’opérateur NOT pour recherche toutes les lignes qui ne sont pas
égales à l’une des valeurs stipulées.

Simplicité de l’opérateur IN
La syntaxe utilisée avec l’opérateur est plus simple que d’utiliser une succession d’opérateur OR.
Pour le montrer concrètement avec un exemple, voici 2 requêtes qui retournerons les mêmes
résultats, l’une utilise l’opérateur IN, tandis que l’autre utilise plusieurs OR.

Requête avec plusieurs OR


SELECT prenom
FROM utilisateur
WHERE prenom = 'Maurice' OR prenom = 'Marie' OR prenom = 'Thimoté'

Requête équivalent avec l’opérateur IN


SELECT prenom
FROM utilisateur
WHERE prenom IN ( 'Maurice', 'Marie', 'Thimoté' )

Exemple
Imaginons une table « adresse » qui contient une liste d’adresse associée à des utilisateurs d’une
application.

id id_utilisateur addr_rue addr_code_postal addr_ville


1 23 35 Rue Madeleine Pelletier 25250 Bournois
2 43 21 Rue du Moulin Collet 75006 Paris

10/34 sql.sh
3 65 28 Avenue de Cornouaille 27220 Mousseaux-Neuville
4 67 41 Rue Marcel de la Provoté 76430 Graimbouville
5 68 18 Avenue de Navarre 75009 Paris

Si l’ont souhaite obtenir les enregistrements des adresses de Paris et de Graimbouville, il est
possible d’utiliser la requête suivante :

SELECT *
FROM adresse
WHERE addr_ville IN ( 'Paris', 'Graimbouville' )

Résultats :

id id_utilisateur addr_rue addr_code_postal addr_ville


2 43 21 Rue du Moulin Collet 75006 Paris
4 67 41 Rue Marcel de la Provoté 76430 Graimbouville
5 68 18 Avenue de Navarre 75009 Paris

SQL BETWEEN
L’opérateur BETWEEN est utilisé dans une requête SQL pour sélectionner un intervalle de données
dans une requête utilisant WHERE. L’intervalle peut être constitué de chaînes de caractères, de
nombres ou de dates. L’exemple le plus concret consiste par exemple à récupérer uniquement les
enregistrements entre 2 dates définies.

Syntaxe
L’utilisation de la commande BETWEEN s’effectue de la manière suivante :

SELECT *
FROM table
WHERE nom_colonne BETWEEN 'valeur1' AND 'valeur2'

La requête suivante retournera toutes les lignes dont la valeur de la colonne « nom_colonne » sera
comprise entre valeur1 et valeur2.

Exemple : filtrer entre 2 dates


Imaginons une table « utilisateur » qui contient les membres d’une application en ligne.

id nom date_inscription
1 Maurice 2012-03-02
2 Simon 2012-03-05
3 Chloé 2012-04-14
4 Marie 2012-04-15
5 Clémentine 2012-04-26

11/34 sql.sh
Si l’ont souhaite obtenir les membres qui se sont inscrit entre le 1 avril 2012 et le 20 avril 2012 il est
possible d’effectuer la requête suivante :

SELECT *
FROM utilisateur
WHERE date_inscription BETWEEN ’2012-04-01′ AND ’2012-04-20′

Résultat :

id nom date_inscription
3 Chloé 2012-04-14
4 Marie 2012-04-15

Exemple : filtrer entre 2 entiers


Si l’ont souhaite obtenir tous les résultats dont l’identifiant n’est pas situé entre 4 et 10, il faudra alors
utiliser la requête suivante :
SELECT *
FROM utilisateur
WHERE id NOT BETWEEN 4 AND 10

Résultat :

id nom date_inscription
1 Maurice 2012-03-02
2 Simon 2012-03-05
3 Chloé 2012-04-14

SQL LIKE
L’opérateur LIKE est utilisé dans la clause WHERE des requêtes SQL. Ce mot-clé permet d’effectuer
une recherche sur un modèle particulier. Il est par exemple possible de rechercher les
enregistrements dont la valeur d’une colonne commence par telle ou telle lettre. Les modèles de
recherches sont multiple.

Syntaxe
La syntaxe à utiliser pour utiliser l’opérateur LIKE est la suivante :

SELECT *
FROM table
WHERE colonne LIKE modele

Dans cet exemple le « modèle » n’a pas été défini, mais il ressemble très généralement à l’un des
exemples suivants :
• LIKE ‘%a’ : le caractère « % » est un caractère joker qui remplace tous les autres caractères.
Ainsi, ce modèle permet de rechercher toutes les chaines de caractère qui se termine par un «
a ».
12/34 sql.sh
• LIKE ‘a%’ : ce modèle permet de rechercher toutes les lignes de « colonne » qui commence
par un « a ».
• LIKE ‘%a%’ : ce modèle est utilisé pour rechercher tous les enregistrement qui utilisent le
caractère « a ».
• LIKE ‘pa%on’ : ce modèle permet de rechercher les chaines qui commence par « pa » et qui
se terminent par « on », comme « pantalon » ou « pardon ».
• LIKE ‘a_c’ : peu utilisé, le caractère « _ » (underscore) peut être remplacé par n’importe quel
caractère, mais un seul caractère uniquement (alors que le symbole pourcentage « % » peut
être remplacé par un nombre incalculable de caractères . Ainsi, ce modèle permet de
retourner les lignes « aac », « abc » ou même « azc ».

Exemple
Imaginons une table « client » qui contient les enregistrement d’utilisateurs :
id nom ville
1 Léon Lyon
2 Odette Nice
3 Vivien Nantes
4 Etienne Lille

Obtenir les résultats qui commencent par « N »


Si l’ont souhaite obtenir uniquement les clients des villes qui commencent par un « N », il est
possible d’utiliser la requête suivante :

SELECT *
FROM client
WHERE ville LIKE 'N%'

Avec cette requête, seul les enregistrements suivants seront retournés :

id nom ville
2 Odette Nice
3 Vivien Nantes

Obtenir les résultats terminent par « e »


Requête :

SELECT *
FROM client
WHERE ville LIKE '%e'

Résultat :

id nom ville
2 Odette Nice
4 Etienne Lille

13/34 sql.sh
SQL GROUP BY
La commande GROUP BY est utilisée en SQL pour grouper plusieurs résultats et utiliser une fonction
de totaux sur un groupe de résultat. Sur une table qui contient toutes les ventes d’un magasin, il est
par exemple possible de liste regrouper les ventes par clients identiques et d’obtenir le coût total des
achats pour chaque client.

Syntaxe d’utilisation de GROUP BY


De façon générale, la commande GROUP BY s’utilise de la façon suivante :

SELECT colonne1, fonction(colonne2)


FROM table
GROUP BY colonne1

A noter : cette commande doit toujours s’utiliser après la commande WHERE et avant la commande
HAVING.

Exemple d’utilisation
Prenons en considération une table « achat » qui résume les ventes d’une boutique :

id client tarif date


1 Pierre 102 2012-10-23
2 Simon 47 2012-10-27
3 Marie 18 2012-11-05
4 Marie 20 2012-11-14
5 Pierre 160 2012-12-03

Ce tableau contient une colonne qui sert d’identifiant pour chaque ligne, une autre qui contient le
nom du client, le coût de la vente et la date d’achat.

Pour obtenir le coût total de chaque client en regroupant les commandes des mêmes clients, il faut
utiliser la requête suivante :

SELECT client, SUM(tarif)


FROM achat
GROUP BY client

La fonction SUM() permet d’additionner la valeur de chaque tarif pour un même client. Le résultat
sera donc le suivant :

client SUM(tarif)
Pierre 262
Simon 47
Marie 38

14/34 sql.sh
La manière simple de comprendre le GROUP BY c’est tout simplement d’assimiler qu’il va éviter de
présenter plusieurs fois les mêmes lignes. C’est une méthode pour éviter les doublons.

Juste à titre informatif, voici ce qu’on obtient de la requête sans utiliser GROUP BY.

Requête :

SELECT client, SUM(tarif)


FROM achat

Résultat :

client SUM(tarif)
Pierre 262
Simon 47
Marie 38
Marie 38
Pierre 262

Utilisation d’autres fonctions de statistiques


Il existe plusieurs fonctions qui peuvent être utilisées pour manipuler plusieurs enregistrements, il
s’agit des fonctions d’agrégations statistiques, les principales sont les suivantes :
• AVG() pour calculer la moyenne d’un set de valeur. Permet de connaître le prix du panier
moyen pour de chaque client
• COUNT() pour compter le nombre de lignes concernées. Permet de savoir combien d’achats a
été effectué par chaque client
• MAX() pour récupérer la plus haute valeur. Pratique pour savoir l’achat le plus cher
• MIN() pour récupérer la plus petite valeur. Utile par exemple pour connaître la date du premier
achat d’un client
• SUM() pour calculer la somme de plusieurs lignes. Permet par exemple de connaître le total
de tous les achats d’un client
Ces petites fonctions se révèlent rapidement indispensable pour travailler sur des données.

15/34 sql.sh
SQL HAVING
La condition HAVING en SQL est presque similaire à WHERE à la seule différence que HAVING
permet de filtrer en utilisant des fonctions telles que SUM(), COUNT(), AVG(), MIN() ou MAX().

Syntaxe
L’utilisation de HAVING s’utilise de la manière suivante :

SELECT colonne1, SUM(colonne2)


FROM nom_table
GROUP BY colonne1
HAVING fonction(colonne2) operateur valeur

Cela permet donc de SÉLECTIONNER les colonnes DE la table « nom_table » en GROUPANT les
lignes qui ont des valeurs identiques sur la colonne « colonne1″ et que la condition de HAVING soit
respectée.

Important : HAVING est très souvent utilisé en même temps que GROUP BY bien que ce ne soit
pas obligatoire.

Exemple
Pour utiliser un exemple concret, imaginons une table « achat » qui contient les achats de différents
clients avec le coût du panier pour chaque achat.

id client tarif date_achat


1 Pierre 102 2012-10-23
2 Simon 47 2012-10-27
3 Marie 18 2012-11-05
4 Marie 20 2012-11-14
5 Pierre 160 2012-12-03

Si dans cette table on souhaite récupérer la liste des clients qui ont commandé plus de 40€, toute
commandes confondu alors il est possible d’utiliser la requête suivante :

SELECT client, SUM(tarif)


FROM achat
GROUP BY client
HAVING SUM(tarif) > 40

Résultat :

client SUM(tarif)
Pierre 162
Simon 47

16/34 sql.sh
SQL ORDER BY
La commande ORDER BY permet de trier les lignes dans un résultat d’une requête SQL. Il est
possible de trier les données sur une ou plusieurs colonnes, par ordre ascendant ou descendant.

Syntaxe
Une requête où l’ont souhaite filtrer l’ordre des résultats utilise la commande ORDER BY de la sorte :

SELECT colonne1, colonne2


FROM table
ORDER BY colonne1

Par défaut les résultats sont classés par ordre ascendant, toutefois il est possible d’inverser l’ordre
en utilisant le suffixe DESC après le nom de la colonne. Par ailleurs, il est possible de trier sur
plusieurs colonnes en les séparant par une virgule. Une requête plus élaboré ressemblerais alors
cela :

SELECT colonne1, colonne2, colonne3


FROM table
ORDER BY colonne1 DESC, colonne2 ASC

A noter : il n’est pas obligé d’utiliser le suffixe « ASC » sachant que les résultats sont toujours classé
par ordre ascendant par défaut. Toutefois, c’est plus pratique pour mieux s’y retrouver, surtout si on a
oublié l’ordre par défaut.

Exemple
Pour l’ensemble de nos exemple, nous allons prendre un base « utilisateur » de test, qui contient les
données suivantes :

id nom prenom date_inscription tarif_total


1 Durand Maurice 2012-02-05 145
2 Dupond Fabrice 2012-02-07 65
3 Durand Fabienne 2012-02-13 90
4 Dubois Chloé 2012-02-16 98
5 Dubois Simon 2012-02-23 27

Pour récupérer la liste de ces utilisateurs par ordre alphabétique du nom de famille, il est possible
d’utiliser la requête suivante :

SELECT *
FROM utilisateur
ORDER BY nom

17/34 sql.sh
Résultat :
id nom prenom date_inscription tarif_total
4 Dubois Chloé 2012-02-16 98
5 Dubois Simon 2012-02-23 27
2 Dupond Fabrice 2012-02-07 65
1 Durand Maurice 2012-02-05 145
3 Durand Fabienne 2012-02-13 90

En utilisant deux méthodes de tri, il est possible de retourner les utilisateurs par ordre alphabétique
ET pour ceux qui ont le même nom de famille, les trier par ordre décroissant d’inscription. La requête
serait alors la suivante :

SELECT *
FROM utilisateur
ORDER BY nom, date_inscription DESC

Résultat :

id nom prenom date_inscription tarif_total


5 Dubois Simon 2012-02-23 27
4 Dubois Chloé 2012-02-16 98
2 Dupond Fabrice 2012-02-07 65
3 Durand Fabienne 2012-02-13 90
1 Durand Maurice 2012-02-05 145

SQL INSERT INTO


L’insertion de données dans une table s’effectue à l’aide de la commande INSERT INTO. Cette
commande permet au choix d’inclure une seule ligne à la base existante ou plusieurs lignes d’un
coup.

Insertion d’une ligne à la fois


Pour insérer des données dans une base, il y a 2 syntaxes principales :
• Insérer une ligne en indiquant les informations pour chaque colonne existante (en respectant
l’ordre)
• Insérer une ligne en spécifiant les colonnes que vous souhaiter compléter. Il est possible
d’insérer une ligne en renseigner seulement une partie des colonnes
Insérer une ligne en spécifiant toutes les colonnes
La syntaxe pour remplir une ligne avec cette méthode est la suivante :

INSERT INTO table


VALUES ('valeur 1', 'valeur 2', ...)

Cette syntaxe possède les avantages et inconvénients suivants :

18/34 sql.sh
• Obliger de remplir toutes les données, tout en respectant l’ordre des colonnes
• Il n’y a pas le nom de colonne, donc les fautes de frappe sont limitées. Par ailleurs, les
colonnes peuvent être renommées sans avoir à changer la requête
• L’ordre des colonnes doit resté identique sinon certaines valeurs prennent le risque d’être
complétée dans la mauvaise colonne
Insérer une ligne en spécifiant seulement les colonnes souhaitées
Cette deuxième solution est très similaire, excepté qu’il faut indiquer le nom des colonnes avant «
VALUES ». La syntaxe est la suivante :

INSERT INTO table


(nom_colonne_1, nom_colonne_2, ...
VALUES ('valeur 1', 'valeur 2', ...)

A noter : il est possible de ne pas renseigner toutes les colonnes. De plus, l’ordre des colonnes n’est
pas important.

Insertion de plusieurs lignes à la fois


Il est possible d’ajouter plusieurs lignes à un tableau avec une seule requête. Pour ce faire, il
convient d’utiliser la syntaxe suivante :

INSERT INTO client (prenom, nom, ville, age)


VALUES
('Rébecca', 'Armand', 'Saint-Didier-des-Bois', 24),
('Aimée', 'Hebert', 'Marigny-le-Châtel', 36),
('Marielle', 'Ribeiro', 'Maillères', 27),

('Hilaire', 'Savary', 'Conie-Molitard', 58);

A noter : lorsque le champ à remplir est de type VARCHAR ou TEXT il faut indiquer le texte entre
guillemet simple. En revanche, lorsque la colonne est un numérique tel que INT ou BIGINT il n’y a
pas besoin d’utiliser de guillemet, il suffit juste d’indiquer le nombre.

Un tel exemple sur une table vide va créer le tableau suivant :

id prenom nom ville age


1 Rébecca Armand Saint-Didier-des-Bois 24
2 Aimée Hebert Marigny-le-Châtel 36
3 Marielle Ribeiro Maillères 27
4 Hilaire Savary Conie-Molitard 58

19/34 sql.sh
SQL UPDATE
La commande UPDATE permet d’effectuer des modifications sur des lignes existantes. Très souvent
cette commande est utilisée avec WHERE pour spécifier sur quelles lignes doivent porter la ou les
modifications.

Syntaxe
La syntaxe basique d’une requête utilisant UPDATE est la suivante :

UPDATE table
SET nom_colonne_1 = 'nouvelle valeur'
WHERE condition

Cette syntaxe permet d’attribuer une nouvelle valeur à la colonne nom_colonne_1 pour les lignes qui
respectent la condition stipulé avec WHERE. Il est aussi possible d’attribuer la même valeur à la
colonne nom_colonne_1 pour toutes les lignes d’une table si la condition WHERE n’était pas utilisée.

A noter, pour spécifier en une seule fois plusieurs modification, il faut séparer les attributions de
valeur par des virgules. Ainsi la syntaxe deviendrait la suivante :

UPDATE table
SET colonne_1 = 'valeur 1', colonne_2 = 'valeur 2', colonne_3 = 'valeur 3'
WHERE condition

Exemple
id nom rue ville code_postal pays
1 Chantal 12 Avenue du Petit Trianon Puteaux 92800 France
2 Pierre 18 Rue de l'Allier Ponthion 51300 France
3 Romain 3 Chemin du Chiron Trévérien 35190 France

Imaginons une table « client » qui présente les coordonnées de clients.

Pour modifier l’adresse du client Pierre, il est possible d’utiliser la requête suivante :

UPDATE client
SET rue = '49 Rue Ameline',
ville = 'Saint-Eustache-la-Forêt',
code_postal = '76210'
WHERE id = 2

Résultat :

id nom rue ville code_postal pays


1 Chantal 12 Avenue du Petit Trianon Puteaux 92800 France
2 Pierre 49 Rue Ameline Saint-Eustache-la-Forêt 76210 France
3 Romain 3 Chemin du Chiron Trévérien 35190 France

20/34 sql.sh
SQL DELETE
La commande DELETE en SQL permet de supprimer des lignes dans une table. En utilisant cette
commande associé à WHERE il est possible de sélectionner les lignes concernées qui seront
supprimées.

Attention : Avant d’essayer de supprimer des lignes, il est recommandé d’effectuer une sauvegarde
de la base de données, ou tout du moins de la table concernée par la suppression. Ainsi, s’il y a une
mauvaise manipulation il est toujours possible de restaurer les données.

Syntaxe
La syntaxe pour supprimer des lignes est la suivante :

DELETE FROM table


WHERE condition

Attention : s’il n’y a pas de condition WHERE alors toutes les lignes seront supprimées et la table
sera alors vide.

Exemple
Imaginons une table « utilisateur » qui contient des informations sur les utilisateurs d’une application.
id nom prenom date_inscription
1 Bazin Daniel 2012-02-13
2 Favre Constantin 2012-04-03
3 Clerc Guillaume 2012-04-12
4 Ricard Rosemonde 2012-06-24
5 Martin Natalie 2012-07-02

Si l’ont souhaite supprimer les utilisateurs qui se sont inscrit avant le « 10/04/2012″, il va falloir
effectuer la requête suivante :

DELETE FROM utilisateur


WHERE date_inscription < '2012-04-10'

La requête permettra alors de supprimer les utilisateurs « Daniel » et « Constantin ». La table


contiendra alors les données suivantes :

id nom prenom date_inscription


3 Clerc Guillaume 2012-04-12
4 Ricard Rosemonde 2012-06-24
5 Martin Natalie 2012-07-02
Il ne faut pas oublier qu’il est possible d’utiliser d’autres conditions pour sélectionner les lignes à
supprimer.

21/34 sql.sh
SQL CREATE DATABASE
La création d’une base de données en SQL est possible en ligne de commande. Même si les
systèmes de gestion de base de données (SGBD) sont souvent utilisés pour créer une base, il
convient de connaître la commande à utiliser, qui est très simple.

Syntaxe
Pour créer une base de données qui sera appelé « ma_base » il suffit d’utiliser la requête suivante
qui est très simple :

CREATE DATABASE ma_base

Base du même nom qui existe déjà


Avec MySQL, si une base de données porte déjà ce nom, la requête retournera une erreur. Pour
éviter d’avoir cette erreur, il convient d’utiliser la requête suivante pour MySQL :

CREATE DATABASE IF NOT EXISTS ma_base

L’option IF NOT EXISTS permet juste de ne pas retourner d’erreur si une base du même nom existe
déjà. La base de données ne sera pas écrasée.

Options
Dans le standard SQL la commande CREATE DATABASE n’existe normalement pas. En conséquent
il revient de vérifier la documentation des différents SGBD pour vérifier les syntaxes possibles pour
définir des options. Ces options permettent selon les cas, de définir les jeux de caractères, le
propriétaire de la base ou même les limites de connexion.

SQL DROP DATABASE


En SQL, la commande DROP DATABASE permet de supprimer totalement une base de données et
tout ce qu’elle contient. Cette commande est à utiliser avec beaucoup d’attention car elle permet de
supprimer tout ce qui est inclus dans une base: les tables, les données, les index …

Syntaxe
Pour supprimer la base de données « ma_base », la requête est la suivante :

DROP DATABASE ma_base

Attention : cela va supprimer toutes les tables et toutes les données de cette base. Si vous n’êtes
pas sûr de ce que vous faites, n’hésitez pas à effectuer une sauvegarde de la base avant de
supprimer.

Ne pas afficher d’erreur si la base n’existe pas


Par défaut, si le nom de base utilisé n’existe pas, la requête retournera une erreur. Pour éviter
d’obtenir cette erreur si vous n’êtes pas sûr du nom, il est possible d’utiliser l’option IF EXISTS. La
syntaxe sera alors la suivante :

DROP DATABASE IF EXISTS ma_base 22/34 sql.sh


SQL CREATE TABLE
La commande CREATE TABLE permet de créer une table en SQL. Un tableau est une entité qui est
contenu dans une base de données pour stocker des données ordonnées dans des colonnes. La
création d’une table sert à définir les colonnes et le type de données qui seront contenus dans
chacun des colonne (entier, chaîne de caractères, date, valeur binaire …).

Syntaxe
La syntaxe générale pour créer une table est la suivante :

CREATE TABLE nom_de_la_table


(
colonne1 type_donnees,
colonne2 type_donnees,
colonne3 type_donnees,
colonne4 type_donnees
)

Dans cette requête, 4 colonnes ont été définies. Le mot-clé « type_donnees » sera à remplacer par
un mot-clé pour définir le type de données (INT, DATE, TEXT …). Pour chaque colonne, il est
également possible de définir des options telles que (liste non-exhaustive) :
• NOT NULL : empêche d’enregistrer une valeur nulle pour une colonne.
• DEFAULT : attribuer une valeur par défaut si aucune données n’est indiquée pour cette
colonne lors de l’ajout d’une ligne dans la table.
• PRIMARY KEY : indiquer si cette colonne est considérée comme clé primaire pour un index.

Exemple
Imaginons que l’ont souhaite créer une table utilisateur, dans laquelle chaque ligne correspond à un
utilisateur inscrit sur un site web. La requête pour créer cette table peut ressembler à ceci :

CREATE TABLE utilisateur


(
id INT PRIMARY KEY NOT NULL,
nom VARCHAR(100),
prenom VARCHAR(100),
email VARCHAR(255),
date_naissance DATE,
pays VARCHAR(255),
ville VARCHAR(255),
code_postal VARCHAR(5),
nombre_achat INT
)

Voici des explications sur les colonnes créées :


• id : identifiant unique qui est utilisé comme clé primaire et qui n’est pas nulle
• nom : nom de l’utilisateur dans une colonne de type VARCHAR avec un maximum de 100

23/34 sql.sh
caractères au maximum
• prenom : idem mais pour le prénom
• email : adresse email enregistré sous 255 caractères au maximum
• date_naissance : date de naissance enregistré au format AAAA-MM-JJ (exemple : 1973-11-
17)
• pays : nom du pays de l’utilisateur sous 255 caractères au maximum
• ville : idem pour la ville
• code_postal : 5 caractères du code postal
• nombre_achat : nombre d’achat de cet utilisateur sur le site

SQL ALTER TABLE


La commande ALTER TABLE en SQL permet de modifier une table existante. Il est ainsi possible
d’ajouter une colonne, d’en supprimer une ou de modifier une colonne existante, par exemple pour
changer le type.

Syntaxe de base
D’une manière générale, la commande s’utilise de la manière suivante :

ALTER TABLE nom_table


instruction

Le mot-clé « instruction » ici sert à désigner une commande supplémentaire, qui sera détaillée ci-
dessous selon l’action que l’ont souhaite effectuer : ajouter, supprimer ou modifier une colonne.

Ajouter une colonne


Syntaxe
L’ajout d’une colonne dans une table est relativement simple et peut s’effectuer à l’aide d’une requête
ressemblant à ceci :

ALTER TABLE nom_table


ADD nom_colonne type_donnees

Exemple
Pour ajouter une colonne qui correspond à une rue sur une table utilisateur, il est possible d’utiliser la
requête suivante :

ALTER TABLE utilisateur


ADD adresse_rue VARCHAR(255)

Supprimer une colonne


Une syntaxe permet également de supprimer une colonne pour une table. Il y a 2 manières
totalement équivalente pour supprimer une colonne :

ALTER TABLE nom_table


DROP nom_colonne

Ou (le résultat sera le même)


24/34 sql.sh
ALTER TABLE nom_table
DROP COLUMN nom_colonne

Modifier une colonne


Pour modifier une colonne, comme par exemple changer le type d’une colonne, il y a différentes
syntaxes selon le SGBD.

MySQL
ALTER TABLE nom_table
MODIFY nom_colonne type_donnees

PostgreSQL
ALTER TABLE nom_table
ALTER COLUMN nom_colonne TYPE type_donnees

Ici, le mot-clé « type_donnees » est à remplacer par un type de données tel que INT, VARCHAR,
TEXT, DATE …

Renommer une colonne


Pour renommer une colonne, il convient d’indiquer l’ancien nom de la colonne et le nouveau nom de
celle-ci.

MySQL
Pour MySQL, il faut également indiquer le type de la colonne.

ALTER TABLE nom_table


CHANGE colonne_ancien_nom colonne_nouveau_nom type_donnees

Ici « type_donnees » peut correspondre par exemple à INT, VARCHAR, TEXT, DATE …

PostgreSQL
Pour PostgreSQL la syntaxe est plus simple et ressemble à ceci (le type n’est pas demandé) :

ALTER TABLE nom_table


RENAME COLUMN colonne_ancien_nom TO colonne_nouveau_nom

25/34 sql.sh
SQL DROP TABLE
La commande DROP TABLE en SQL permet de supprimer définitivement une table d’une base de
données. Cela supprime en même temps les éventuels index, trigger, contraintes et permissions
associées à cette table.

Attention : il faut utiliser cette commande avec attention car une fois supprimée, les données sont
perdues. Avant de l’utiliser sur une base importante il peut être judicieux d’effectuer un backup (une
sauvegarde) pour éviter les mauvaises surprises.

Syntaxe
Pour supprimer une table « nom_table » il suffit simplement d’utiliser la syntaxe suivante :

DROP TABLE nom_table

A savoir : s’il y a une dépence avec une autre table, il est recommandé de les supprimer avant de
supprimer la table. C’est le cas par exemple s’il y a des clés étrangères.

Intérêts
Il arrive qu’une table soit créé temporairement pour stoquer des données qui n’ont pas vocation à
être ré-utiliser. La suppression d’une table non utilisée est avantageux sur plusieurs aspects :
• Libérer de la mémoire et alléger le poids des backups
• Éviter des erreurs dans le futur si une table porte un nom similaire ou qui porte à confusion
• Lorsqu’un développeur ou administrateur de base de données découvre une application, il est
plus rapide de comprendre le système s’il n’y a que les tables utilisées qui sont présente

Exemple de requête
Imaginons qu’une base de données possède une table « client_2009 » qui ne sera plus jamais utilisé
et qui existe déjà dans un ancien backup. Pour supprimer cette table, il suffit d’effectuer la requête
suivante :

DROP TABLE client_2009

L’exécution de cette requête va permettre de supprimer la table.

Jointure SQL
Les jointures en SQL permettent d’associer plusieurs tables dans une même requête. Cela permet
d’exploiter la puissance des bases de données relationnelles pour obtenir des résultats qui
combinent les données de plusieurs tables de manière efficace.

Types de jointures
Il y a plusieurs méthodes pour associer 2 tables ensemble. Voici la liste des différentes techniques
qui sont utilisées :
• INNER JOIN : jointure interne pour retourner les enregistrements quand la condition est vrai
dans les 2 tables. C’est l’une des jointures les plus communes.
• CROSS JOIN : jointure croisée permettant de faire le produit cartésien de 2 tables. En
d’autres mots, permet de joindre chaque lignes d’une table avec chaque lignes d’une seconde
26/34 sql.sh
table. Attention, le nombre de résultats est en général très élevé.
• LEFT JOIN (ou LEFT OUTER JOIN) : jointure externe pour retourner tous les
enregistrements de la table de gauche (LEFT = gauche) même si la condition n’est pas vérifié
dans l’autre table.
• RIGHT JOIN (ou RIGHT OUTER JOIN) : jointure externe pour retourner tous les
enregistrements de la table de droite (RIGHT = droite) même si la condition n’est pas vérifié
dans l’autre table.
• FULL JOIN (ou FULL OUTER JOIN) : jointure externe pour retourner les résultats quand la
condition est vrai dans au moins une des 2 tables.
• SELF JOIN : permet d’effectuer une jointure d’une table avec elle-même comme si c’était une
autre table.
• NATURAL JOIN : jointure naturelle entre 2 tables s’il y a au moins une colonne qui porte le
même nom entre les 2 tables SQL
• UNION JOIN : jointure d’union

SQL INNER JOIN


Dans le langage SQL la commande INNER JOIN, aussi appelée EQUIJOIN, est un type de jointures
très communes pour lier plusieurs tables entre-elles. Cette commande retourne les enregistrements
lorsqu’il y a au moins une ligne dans chaque colonne qui correspond à la condition.

Syntaxe
Pour utiliser ce type de jointure il convient d’utiliser une requête SQL avec cette syntaxe :

SELECT *
FROM table1
INNER JOIN table2 ON table1.id = table2.fk_id

La syntaxe ci-dessus stipule qu’il faut sélectionner les enregistrements des tables table1 et table2
lorsque les données de la colonne « id » de table1 est égal aux données de la colonne fk_id de
table2.

La jointure SQL peux aussi être écrite de la façon suivante :

SELECT *
FROM table1
INNER JOIN table2
WHERE table1.id = table2.fk_id

La syntaxe avec la condition WHERE est une manière alternative de faire la jointure mais qui
possède l’inconvénient d’être moins facile à lire s’il y a déjà plusieurs conditions dans le WHERE.

Exemple
Imaginons une application qui possède une table utilisateur ainsi qu’une table commande qui
contient toutes les commandes effectuées par les utilisateurs.

Table utilisateur :

id prenom nom email ville


1 Aimée Marechal aime.marechal@example.com Paris

27/34 sql.sh
2 Esmée Lefort esmee.lefort@example.com Lyon
3 Marine Prevost m.prevost@example.com Lille
4 Luc Rolland lucrolland@example.com Marseille

Table commande :
utilisateur_id date_achat num_facture prix_total
1 2013-01-23 A00103 203.14
1 2013-02-14 A00104 124.00
2 2013-02-17 A00105 149.45
2 2013-02-21 A00106 235.35
5 2013-03-02 A00107 47.58

Pour afficher toutes les commandes associées aux utilisateurs, il est possible d’utiliser la requête
suivante :

SELECT id, prenom, nom, date_achat, num_facture, prix_total


FROM utilisateur
INNER JOIN commande ON utilisateur.id = commande.utilisateur_id

Résultats :

id prenom nom date_achat num_facture prix_total


1 Aimée Marechal 2013-01-23 A00103 203.14
1 Aimée Marechal 2013-02-14 A00104 124.00
2 Esmée Lefort 2013-02-17 A00105 149.45
2 Esmée Lefort 2013-02-21 A00106 235.35

Le résultat de la requête montre parfaite la jointure entre les 2 tables. Les utilisateurs 3 et 4 ne sont
pas affichés puisqu’il n’y a pas de commandes associés à ces utilisateurs.

Attention : il est important de noter que si un utilisateur à été supprimé, alors on ne verra pas ses
commandes dans la liste puisque INNER JOIN retourne uniquement les résultats ou la condition est
vrai dans les 2 tables.

28/34 sql.sh
SQL Sous-requête
Dans le langage SQL une sous-requête (aussi appelé « requête imbriquée » ou « requête en
cascade ») consiste à exécuter une requête à l’intérieur d’une autre requête. Une requête imbriquée
est souvent utilisée au sein d’une clause WHERE ou de HAVING pou remplacer une ou plusieurs
constante.

Syntaxe
Il y a plusieurs façons d’utiliser les sous-requêtes. De cette façon il y a plusieurs syntaxes
envisageables pour utiliser des requêtes dans des requêtes.

Requête imbriquée qui retourne un seul résultat


L’exemple ci-dessous est une exemple typique d’une sous-requête qui retourne un seul résultat à la
requête principale.

SELECT *
FROM `table`
WHERE `nom_colonne` = (
SELECT `valeur`
FROM `table2`
LIMIT 1
)

Cet exemple montre une requête interne (celle sur « table2″) qui renvoi une seule valeur. La requête
externe quant à elle, va chercher les résultat de « table » et filtre les résultats à partir de la valeur
retournée par la requête interne.

A noter : il est possible d’utiliser n’importe quel opérateur d’égalité tel que =, >, <, >=, <= ou <>.

Requête imbriquée qui retourne une colonne


Une requête imbriquée peut également retournée une colonne entière. Dès lors, la requête externe
peut utiliser la commande IN pour filtrer les lignes qui possèdent une des valeurs retournées par la
requête interne. L’exemple ci-dessous met en évidence un tel cas de figure :

SELECT *
FROM `table`
WHERE `nom_colonne` IN (
SELECT `colonne`
FROM `table2`
WHERE `cle_etrangere` = 36
)

Exemple
La suite de cet article présente des exemples concrets utilisant les sous-requêtes.

29/34 sql.sh
Imaginons un site web qui permet de poser des questions et d’y répondre. Un tel site possède une
base de données avec une table pour les questions et une autre pour les réponses.

Table « question » :

q_id q_date_ajout q_titre q_contenu


1 2013-03-24 Comment réparer un Bonjour, j'ai mon ordinateur de cassé, comment puis-je
12:54:32 ordinateur? procéder pour le réparer?
2 2013-03-26 Comment changer Quel est la meilleur méthode pour changer un pneu
19:27:41 un pneu? facilement ?
3 2013-04-18 Que faire si un Est-il préférable de réparer les appareils électriques ou
20:09:56 appareil est cassé? d'en acheter de nouveaux?
4 2013-04-22 Comment faire Bonjour, sous mon clavier d'ordinateur il y a beaucoup
17:14:27 nettoyer un clavier de poussière, comment faut-il procéder pour le nettoyer?
d'ordinateur? Merci.

Table « reponse » :

r_id r_fk_question_id r_date_ajout r_contenu


1 1 2013-03-27 Bonjour. Pouvez-vous expliquer ce qui ne fonctionne pas
07:44:32 avec votre ordinateur? Merci.
2 1 2013-03-28 Bonsoir, le plus simple consiste à faire appel à un
19:27:11 professionnel pour réparer un ordinateur. Cordialement,
3 2 2013-05-09 Des conseils son disponible sur internet sur ce sujet.
22:10:09
4 3 2013-05-24 Bonjour. Ça dépend de vous, de votre budget et de vos
09:47:12 préférence vis-à-vis de l'écologie. Cordialement,

Requête imbriquée qui retourne un seul résultat


Avec une telle application, il est peut-être utile de connaître la question liée à la dernière réponse
ajoutée sur l’application. Cela peut être effectué via la requête SQL suivante :

SELECT *
FROM `question`
WHERE q_id = (
SELECT r_fk_question_id
FROM `reponse`
ORDER BY r_date_ajout DESC
LIMIT 1
)

Une telle requête va retourner la ligne suivante :

q_id q_date_ajout q_titre q_contenu


3 2013-04-18 Que faire si un Est-il préférable de réparer les appareils électriques ou
20:09:56 appareil est cassé? d'en acheter de nouveaux?

30/34 sql.sh
Ce résultat démontre que la question liée à la dernière réponse sur le forum est bien trouvée à partir
de ce résultat.

Requête imbriquée qui retourne une colonne


Imaginons maintenant que l’ont souhaite obtenir les questions liées à toutes les réponses comprises
entre 2 dates. Ces questions peuvent être récupérée par la requête SQL suivante :

SELECT *
FROM `question`
WHERE q_id IN (
SELECT r_fk_question_id
FROM `reponse`
WHERE r_date_ajout BETWEEN '2013-01-01' AND '2013-12-31'
)

Résultats :

q_id q_date_ajout q_titre q_contenu


1 2013-03-24 Comment réparer un Bonjour, j'ai mon ordinateur de cassé, comment puis-je
12:54:32 ordinateur? procéder pour le réparer?
2 2013-03-26 Comment changer Quel est la meilleur méthode pour changer un pneu
19:27:41 un pneu? facilement ?
3 2013-04-18 Que faire si un Est-il préférable de réparer les appareils électriques ou
20:09:56 appareil est cassé? d'en acheter de nouveaux?

Une telle requête permet donc de récupérer les questions qui ont eu des réponses entre 2 dates.
C’est pratique dans notre cas pour éviter d’obtenir des réponses qui n’ont pas eu de réponses du tout
ou pas de nouvelles réponses depuis longtemps.

31/34 sql.sh
SQL EXISTS
Dans le langage SQL, la commande EXISTS s’utilise dans une clause conditionnelle pour savoir s’il y
a une présence ou non de lignes lors de l’utilisation d’une sous-requête.

A noter : cette commande n’est pas à confondre avec la clause IN. La commande EXISTS vérifie si
la sous-requête retourne un résultat ou non, tandis que IN vérifie la concordance d’une à plusieurs
données.

Syntaxe
L’utilisation basique de la commande EXISTS consiste à vérifier si une sous-requête retourne un
résultat ou non, en utilisant EXISTS dans la clause conditionnelle. La requête externe s’exécutera
uniquement si la requête interne retourne au moins un résultat.

SELECT nom_colonne1
FROM `table1`
WHERE EXISTS (
SELECT nom_colonne2
FROM `table2`
WHERE nom_colonne3 = 10
)

Dans l’exemple ci-dessus, s’il y a au moins une ligne dans table2 dont nom_colonne3 contient la
valeur 10, alors la sous-requête retournera au moins un résultat. Dès lors, la condition sera vérifiée et
la requête principale retournera les résultats de la colonne nom_colonne1 de table1.

Exemple
Dans le but de montrer un exemple concret d’application, imaginons un système composé d’une
table qui contient des commandes et d’une table contenant des produits.

Table commande :

c_id c_date_achat c_produit_id c_quantite_produit


1 2014-01-08 2 1
2 2014-01-24 3 2
3 2014-02-14 8 1
4 2014-03-23 10 1

Table produit :

32/34 sql.sh
p_id p_nom p_date_ajout p_prix
2 Ordinateur 2013-11-17 799.9
3 Clavier 2013-11-27 49.9
4 Souris 2013-12-04 15
5 Ecran 2013-12-15 250

Il est possible d’effectuer une requête SQL qui affiche les commandes pour lesquels il y a
effectivement un produit. Cette requête peut être interprétée de la façon suivante :

SELECT *
FROM commande
WHERE EXISTS (
SELECT *
FROM produit
WHERE c_produit_id = p_id
)

Résultat :

c_id c_date_achat c_produit_id c_quantite_produit


1 2014-01-08 2 1
2 2014-01-24 3 2

Le résultat démontre bien que seul les commandes n°1 et n°2 ont un produit qui se trouve dans la
table produit (cf. la condition c_produit_id = p_id). Cette requête est intéressante sachant qu’elle
n’influence pas le résultat de la requête principale, contrairement à l’utilisation d’une jointure qui va
concaténer les colonnes des 2 tables jointes.

33/34 sql.sh
Commentaires en SQL
Il peut être intéressant d’insérer des commentaires dans les requêtes SQL pour mieux s’y retrouver
lorsqu’il y a de grosses requêtes complexes. Il y a plusieurs façon de faire des commentaires dans le
langage SQL, qui dépendent notamment du Système de Gestion de Base de Données utilisées
(SGBD) et de sa version.

Commentaire double tiret : –


Le double tiret permet de faire un commentaire jusqu’à la fin de la ligne.

Exemple
SELECT * -- tout sélectionner
FROM table1 -- dans la table "table1"

Compatibilité
• Depuis la version 3.23.3 de MySQL
• PostgreSQL
• Oracle
• SQLite

Commentaire dièse : #
Le symbole dièse permet de faire un commentaire jusqu’à la fin de la ligne.

Exemple
SELECT * # tout sélectionner
FROM table1 # dans la table "table1"

Compatibilité
• MySQL

Commentaire multi-ligne : /* et */
Le commentaire multi-ligne à l’avantage de pouvoir indiquer où commence et où se termine le
commentaire. Il est donc possible de l’utiliser en plein milieu d’une requête SQL sans problème.

Exemple
SELECT * /* tout sélectionner */
FROM table1 /* dans la table "table1" */
WHERE 1 = /* exemple en milieu de requete */ 1

Compatibilité
• MySQL
• PostgreSQL
• Oracle
• SQL Server
• SQLite .
34/34 sql.sh

Vous aimerez peut-être aussi