Les requêtes d'interrogation de la base de données en langage SQL
- Fiche de cours
- Quiz
- Profs en ligne
- Videos
- Application mobile
La commande SELECT effectue une projection. SELECT permet d'extraire des données ou de faire des calculs sur les données d'une base. Cette commande suivie du nom d'un champ signifie que ce champ doit être affiché. SELECT est indissociable de la commande FROM. FROM indique de quelle(s) table(s) seront extraites les informations.
FROM nom de la (ou les) table(s) contenant les champs sélectionnés ;
• Exemple :
SELECT Num_client
FROM Client;
= signifie l'affichage des numéros client provenant de la table client.
SUM ( ) |
renvoie la somme d'un champ |
AVG ( ) |
renvoie la moyenne d'un champ |
MAX ( ) |
renvoie la valeur maximale d'un champ |
MIN ( ) |
renvoie la valeur minimale d'un champ |
COUNT ( ) |
renvoie le nombre d'enregistrements de la table |
• Exemple de fonction d'agrégat :
SELECT COUNT(Num_client)
FROM Client ;
= renvoie le nombre d'enregistrements du champ Num_client
Exemple : SELECT * FROM Client donne l'ensemble des champs de la table Client.
• L'opérateur AS permet de donner un nom à un champ d'une requête.
SELECT COUNT(Num_Client) AS Nombre_de_clients FROM Clients ;
Cette requête pourra avoir comme résultat :
Nombre de clients |
125 |
FROM table contenant les champs sélectionnés
WHERE Condition ;
• Exemple :
SELECT N°_telephone
FROM Client
WHERE Nom_Client = "Dupond" ;
= signifie l'affichage du numéro de téléphone du client Dupond. En présence d'une chaîne de caractères, celle-ci doit être saisie entre guillemets. A notre niveau, peu importe que ce soit des guillemets doubles ou des guillemets simples (apostrophes). Quant à la casse (majuscule ou minuscule), il faut la respecter. "dupond" et "DUPOND" ne sont pas identiques dans un système de gestion de bases de données relationnelles.
• les opérateurs arithmétiques : +, -, *, /
• les opérateurs de comparaison : <, >, =
• les opérateurs logiques : AND, OR, NOT
• des comparateurs de chaîne : LIKE, BETWEEN et IN
• Syntaxe
SELECT champ(s) à afficher
FROM tables contenant les champs sélectionnés
WHERE table1.clé primaire = table2.clé étrangère ;
• Exemple :
SELECT Nom_Client, Num_Commande
FROM Client, Commande
WHERE Client.Num_Client = Commande.Num_Client_Cde ;
Deux tables sont ici nécessaires pour afficher le nom du client et le numéro de commande. Une jointure est donc nécessaire. Cette jointure signifie que les valeurs prises par le champ Num_Client (clé primaire) de la table Client doivent être égales aux valeurs prises par le champ Num_Client_Cde (clé étrangère) de la table Commande.
• Syntaxe
SELECT nom du (ou des) champ(s) à sélectionner
FROM nom de la (ou les) table(s) contenant les champs sélectionnés
ORDER BY nom du champ sur le quel s'effectue le tri ;
• Exemple :
SELECT Nom_client, Num_client
FROM Client
ORDER BY Nom_client;
= signifie l'affichage des numéros et des noms des clients par ordre alphabétique.
• Syntaxe
SELECT champs à afficher
FROM tables nécessaires
GROUP BY champ sur lequel s'effectue le regroupement ;
• Exemple :
SELECT Marque, AVG(prix) AS moyenne
FROM Vehicule
GROUP BY Marque ;
= signifie l'affichage des moyennes des prix par marque de véhicule.
• Syntaxe
SELECT champs à afficher
FROM tables nécessaires
GROUP BY champ sur lequel s'effectue le regroupement
HAVING condition spécifique au regroupement ;
• Exemple :
SELECT Marque, AVG(prix) AS moyenne
FROM Vehicule
GROUP BY Marque
HAVING AVG(prix) > 20 000 ;
= signifie l'affichage des moyennes des prix par marque de véhicule pour les marques qui ont une moyenne de prix supérieure à 20 000 €.
SQL est un langage permettant, entre autres, d'interroger et de modifier une base de données. Le langage SQL utilise des commandes.
Une projection s'effectue en SQL avec la commande SELECT…FROM…
Une sélection (ou restriction) s'effectue avec la commande WHERE.
Quand une requête nécessite plusieurs tables, une jointure est nécessaire. Cette jointure se matérialise par la présence d'une commande WHERE.
La commande ORDER BY permet d'effectuer un tri.
La commande GROUP BY permet d'effectuer un regroupement. Cette commande est parfois associée à la commande HAVING qui introduit une restriction dans le regroupement.
• Syntaxe
SELECT champs à afficher
FROM tables nécessaires
WHERE condition
AND critère de jointure
GROUP BY champ sur lequel s'effectue le regroupement
HAVING condition spécifique au regroupement
ORDER BY nom du champ sur lequel s'effectue le tri
Vous avez obtenu75%de bonnes réponses !