Introduction
Le langage SQL est composé de différents sous-ensembles :
- LMD : Langage de Manipulation des données (DML, Data Manipulation Language)
- Permet la manipulation et la mise à jour des tables, composé de quatre ordres fondamentaux :
SELECT
,UPDATE
,INSERT
,DELETE
. - LDD : Langage de Définition des Données (DDL, Data Definition Language)
- Permet la définition et la mise à jour du schéma relationnel de la base de données (mode administration). Composé des ordres suivants :
CREATE TABLE
,CREATE INDEX
,CREATE VIEW
,DROP TABLE
,DROP INDEX
,DROP VIEW
,ALTER TABLE
. - LCD : Langage de Contrôle des Données (DCL, Data Control Language)
- Permet de définir les contraintes d’intégrité, de gérer les accès et les autorisations (administration). Composé des ordres :
GRANT
,REVOKE
,LOCK
. Recouvre les déclencheurs (triggers), procédures cataloguées.
Le programme se limite au sous-ensemble LMD. Nous serons tout de même obligés d’utiliser l’ordre de création de table CREATE TABLE
.
SQLite
Dans ce cours nous utiliserons SQLite depuis l’interface de Repl.it .
SQLite est un moteur de base de données relationnelle (sous-ensemble d’un SGBD) accessible par le langage SQL. Contrairement aux serveurs de bases de données traditionnels, comme MySQL ou PostgreSQL, sa particularité est de ne pas reproduire le schéma habituel client-serveur mais de fonctionner sans serveur (on parle de base de données « standalone » ou « embarquée »). L’intégralité de la base de données (déclarations, tables, index et données) est stockée dans un fichier indépendant de la plateforme.
- Remarque
- On peut accéder à SQLite depuis de nombreux langages de programmation. Nous utiliserons dans un premier temps une interface en ligne de commande (CLI) et par la suite Python.
SQLite est le moteur de base de données le plus utilisé au monde.
Chaque SGBD possède, en plus du SQL, des commandes propres : section 3 de la documentation officielle
Ces dernières commencent toujours par un point en SQLite et ne devront pas être apprises !
Création d’une première base de données
On possède un fichier tableur contenant des informations sur quelques acteurs, parmi les plus célèbres.
Nom | Prénom | Sexe | Pays | Age |
---|---|---|---|---|
Hanks | Tom | Homme | USA | 64 |
Holland | Tom | Homme | Angleterre | 24 |
Johansson | Scarlett | Femme | USA | 36 |
Johnson | Dwayne | Homme | USA | 48 |
Robbie | Margot | Femme | Australie | 30 |
Cotillard | Marion | Femme | France | 45 |
Gadot | Gal | Femme | Israël | 35 |
Cruise | Tom | Homme | USA | 58 |
On souhaite transformer ce fichier en une base de données contenant, pour l’instant, une seule relation.
- Réaliser une copie de l’ environnement de travail sur repl.it
L’instruction de création de la table (relation) est
|
|
-
Indiquer la signification de chaque ligne de la commande.
-
Incorporer la commande au fichier
celebrites.sql
et l’exécuter. -
Afin de vérifier que la commande a bien créé une table dans la base de données qui réside pour l’instant dans la RAM, ajouter la commande suivante au fichier
main.sql
|
|
Relancer l’exécution des commandes et observer le résultat dans la console.
- Afin d’examiner la structure de la table
Celebrites
, ajouter l’une des commandes suivantes au fichiermain.sql
.
|
|
ou
|
|
La commande permettant d’intégrer le tuple ("Hanks", "Tom", "Homme", "USA", 64)
à la relation Celebrites
est :
|
|
-
Intégrer la commande précédente au fichier
celebrites.sql
. Exécuter cette commande. La sortie fait-elle apparaître le résultat de cette commande ? -
Afin de vérifier que les informations ont bien été ajoutées à la base de données, ajouter la commande suivante dans le fichier
main.sql
|
|
Exécuter cette commande.
-
Ajouter maintenant au fichier
celebrites.sql
toutes les commandes permettant de peupler la base de données.
Exécuter ces commandes. -
La base de données réside toujours en mémoire et n’a, pour l’instant, pas été sauvegardée dans un fichier. Ajouter la commande suivante à la fin du fichier
celebrites.sql
|
|
Vérifier que le fichier cinema.sqlite
a bien été créé.
Désormais, à la prochaine utilisation de la base de données il ne sera plus nécessaire de relancer toute la création de la base de données (ce qui pourrait être très très long dans le cas d’une base conséquente) mais seulement la commande
|
|
au début du fichier main.sql
(qui ne devra alors plus lire le fichier celebrites.sql
).
Premières requêtes : Projection
main.sql
après la commande de lecture du fichier celebrites.sql
(ou après la commande de lecture du fichier cinema.sqlite
).
- La commande
SELECT * FROM Celebrites;
est une requête. Que signifie le caractère*
dans cette commande ?
Réponse
Le caractère *
indique que l’on souhaite que la relation retournée par la commande SELECT
contienne tous les attributs (champs).
- Adapter la commande précédente de façon à obtenir tous les noms des acteurs présents dans la base de données.
Réponse
|
|
- Adapter la commande précédente de façon à obtenir tous les noms et sexes des acteurs présents dans la base de données.
Réponse
|
|
Premières requêtes : Sélection
Sélections simples
La sélection consiste à filtrer des enregistrements d’une relation en fonction d’une condition. Le résultat d’une sélection est une relation de même degré mais de cardinalité différente.
Une sélection s’effectue en langage SQL à l’aide de la clause WHERE
.
- Écrire la commande qui retourne toutes les informations relatives aux femmes présentes dans la base de données.
Réponse
|
|
- Adapter la commande précédente de façon à obtenir tous les noms et prénoms des femmes présentes dans la base de données.
Réponse
|
|
Opérateurs de comparaison
- Quels sont les noms de tous les acteurs (sans distinction de sexe) qui n’ont pas pour pays d’origine les USA.
Réponse
|
|
- Quels sont les noms des acteurs (sans distinction de sexe) qui ont plus de 40 ans ?
Réponse
|
|
- Quels sont les noms et prénoms des acteurs (sans distinction de sexe) qui ont plus de 40 ans ?
Réponse
|
|
- Quels sont les noms des acteurs (sans distinction de sexe) qui ont au plus 36 ans ?
Réponse
|
|
- Quels sont les noms des actrices françaises ?
Réponse
|
|
- Quels sont les ages des acteurs américains hommes dont le prénom est Tom ?
Réponse
|
|
- Quels sont les prénoms des acteurs (sans distinction de sexe) australiens ou de plus de 40 ans ?
Réponse
|
|
Exercices d’application
Les sportifs stars
Écrire toutes les commandes correspondant au requêtes ci-dessous pour la base de donnée se trouvant à cette adresse
- Donner le schéma relationnel de la base de données.
- Afficher les noms de tous les sportifs.
- Afficher les noms et prénoms de tous les sportifs.
- Afficher les noms, prénoms et sports de tous les sportifs.
- Afficher le nom des sportifs nés au mois de décembre.
- Afficher les noms et prénoms des sportifs nés en juin.
- Afficher les noms et prénoms des sportifs nés en 1981.
- Afficher les noms et prénoms des sportifs pratiquant le football.
Écrire toutes les commandes correspondant au requêtes ci-dessous pour la base de donnée se trouvant à cette adresse
- Donner le schéma relationnel de la base de données.
- Afficher toutes les informations relatives aux utilisateurs qui ne sont pas des footballeurs.
- Afficher toutes les informations relatives aux utilisateurs qui ont plus de 200 million followers.
- Afficher toutes les informations relatives des utilisateurs qui ont au plus 200 million followers.
- Afficher toutes les informations relatives des utilisateurs qui ont au moins 200 million followers.
- Afficher les prénoms, noms et « Instagram handle » des comptes qui ont au maximum 155 millions de followers.
- Afficher toutes les informations pour les comptes qui correspondent à des chanteurs et qui ont plus de 200 millions de followers.
- Afficher toutes les informations pour les comptes qui correspondent à des footballeurs ou qui ont moins de 150 millions de followers.
Première requêtes : Ordres SQL
Celebrites
.
ORDER BY
est utilisé pour trier le résultat d’une projection. Par défaut ce tri s’effectue par ordre croissant (lexicographique ou numérique). Pour trier par ordre décroissant, il faut ajouter le mot clé DESC
, pour trier par ordre croissant on utilise ASC
.
- Rechercher toutes les informations sur les acteurs, triées par age croissant.
Réponse
|
|
- Rechercher toutes les informations sur les acteurs, triées par pays d’origine (par ordre décroissant).
Réponse
|
|
- Rechercher les noms et prénoms des acteurs triés par age et nom croissants.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs triés par age décroissant et nom croissant.
Réponse
|
|
- Rechercher les ages et sexes des acteurs, triés par age croissant.
Réponse
|
|
BETWEEN
est utilisé pour sélectionner une valeur numérique dans un intervalle.
- Écrire une requête qui affiche toutes les informations sur les artistes dont les ages sont compris entre 30 et 60 ans.
Réponse
|
|
Première requêtes : recherche de motifs lors d’une sélection
Celebrites
.
LIKE
permet de rechercher un motif lors d’une sélection.
- Rechercher les prénoms des acteurs dont le nom commence par la lettre
j
.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le sexe commence par la lettre
h
, trié par nom croissant.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le prénom se termine par la lettre
t
.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le prénom contient la lettre
a
.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le pays d’origine commence par un
a
.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le pays d’origine se termine par un
l
.
Réponse
|
|
- Rechercher les noms et prénoms des acteurs dont le pays d’origine comporte un
a
.
Réponse
|
|
Exercice d’application
Écrire toutes les commandes correspondant au requêtes ci-dessous pour la base de donnée se trouvant à cette adresse
-
Rechercher toutes les informations sur les animaux dont le nom commence par la lettre
p
. -
Rechercher toutes les informations sur les animaux dont le nom se termine par la lettre
e
et qui sont En danger. -
Rechercher toutes les informations sur les animaux dont le nom comporte la lettre
a
et qui sont Vulnérable. Le résultat doit être trié par nom (ascendant). -
Afficher le nom de tous les animaux et leur état de préservation.
-
Afficher le nom de tous les animaux vulnérables par ordre décroissant de la vitesse de déplacement.
-
Afficher le nom et la durée de vie moyenne des animaux dont le nom comporte un
e
. L’affichage doit être effectué par durée de vie moyenne croissante. -
Afficher les nom, durée de vie moyenne et vitesse de déplacement des animaux dont le nom comporte un
o
, par vitesse de déplacement décroissante.
Modification des entrées d’une base de données
Celebrites
.
UPDATE
permet de modifier un enregistrement dans une table. La clause WHERE
est utilisée pour sélectionner l’enregistrement.
- Faire en sorte que l’age de l’actrice Margot Robbie soit égal à 29 ans.
Réponse
|
|
Vérifier que la modification a bien été effectuée.
-
Modifier le fichier contenant la base de données de façon à ce que la modification, uniquement effectuée en mémoire vive pour l’instant, soit enregistrée de façon permanente.
-
Le vrai nom de Tom Cruise est Thomas Cruise Mapother IV. Modifier l’entrée dans la base de données.
Réponse
|
|
DELETE
permet de supprimer un enregistrement d’une table. Si aucune clause WHERE
n’est utilisée, tous les enregistrements de la table sont supprimés.
- Supprimer l’acteur Tom Holland de la table Celebrites.
Réponse
|
|
Exercice d’application
Écrire toutes les commandes correspondant au requêtes ci-dessous pour la base de donnée se trouvant à cette adresse
-
Écrire une requête qui affiche tous les enregistrements de la table « Superheroes and Villains ».
-
Écrire une requête qui affiche la structure de la table « Superheroes and Villains ».
-
Écrire une requête qui affiche les noms des superheroes femmes.
-
Écrire une requête qui affiche les noms et types (gentil ou méchant) des films X-Men ou Guardians of the Galaxy.
-
Écrire une requête qui affiche tous les noms des personnages par ordre alphabétique.
-
Écrire une requête qui affiche les types des personnages et leurs noms par ordre alphabétique croissant pour les types mais ordre alphabétique décroissant pour les noms.
-
Écrire une requête qui affiche les noms des personnages commençant par la lettre
M
. -
Écrire une requête qui affiche les noms des personnages se terminant par la lettre
N
. -
Écrire une requête qui affiche les noms des personnages contenant la lettre
I
. -
Écrire une requête qui modifie le nom du personnage Groot. Le nouveau nom est Baby Groot. Afficher le résultat de cette requête.
-
Écrire une requête qui supprime l’enregistrement dont le nom est Queen of Hearts. Afficher la table pour vérifier le résultat de la requête.
Exercice d’application à partir de données réelles et conséquentes
La base de donnée contient tous les indicateurs des lycées français présentés sur le site de l’éducation nationale et dont les données sont en accès “libre” sur data.gouv.fr . La notice descriptive est fournie.
- Écrire 10 requêtes qui vous semblerons utiliser au mieux cette base de données.