TP Contexte SNCF⚓︎
Objectif du TP
travailler sur la création d'une base de données
Soient les relations suivantes :
GARE (CodeGare, NomGare, NomVille)
TRAIN (NumTrain, #CodGareDep, #CodGareArr, Hdep, Harr, CodTrf)
COMPOSITION (#NumTrain, DatDep, Ass1, Ass2, Cch1, Cch2)
EXCEPTION (#NumTrain, DatDep)
CodTrf : Code trafic (Q: quotidien, D: samedi, dimanche et fêtes)
Ass1, Ass2 : nombre de wagons place assise en 1° classe et 2°classe
Cch1, Cch2 : nombre de wagons couchette en 1° classe et 2° classe
La présence d'un tuple dans l'objet EXCEPTION indique que le train ne roulera pas ce jour là, quel que soit son code trafic.
CREATE DATABASE IF NOT EXISTS sncf ;
Complément de cours
Expression de contraintes d'intégrité
Une contrainte d'intégrité est une clause permettant de contraindre la modification de tables, faite par l'intermédiaire de requêtes d'utilisateurs, afin que les données saisies dans la base soient conformes aux données attendues. Ces contraintes doivent être exprimées dès la création de la table grâce aux mots clés suivants :
```SQL
CONSTRAINT
DEFAULT
NOT NULL
UNIQUE
CHECK
```
Définir une valeur par défaut
Le langage SQL permet de définir une valeur par défaut lorsqu'un champ de la base n'est pas renseigné grâce à la clause DEFAULT
. Cela permet notamment de faciliter la création de tables, ainsi que de garantir qu'un champ ne sera pas vide.
La clause DEFAULT
doit être suivie par la valeur à affecter. Cette valeur peut être un des types suivants :
- constante numérique
- constante alphanumérique (chaîne de caractères)
- le mot clé ``USER`` (nom de l'utilisateur)
- le mot clé ``NULL``
- le mot clé ``CURRENT_DATE`` (date de saisie)
- le mot clé ``CURRENT_TIME`` (heure de saisie)
- le mot clé ``CURRENT_TIMESTAMP`` (date et heure de saisie)
Forcer la saisie d'un champ
Le mot clé NOT NULL
permet de spécifier qu'un champ doit être saisi, c'est-à-dire que le SGBD refusera d'insérer des tuples dont un champ comportant la clause NOT NULL
n'est pas renseigné.
Emettre une condition sur un champ
Il est possible de faire un test sur un champ grâce à la clause CHECK()
comportant une condition logique portant sur une valeur entre les parenthèses. Si la valeur saisie est différente de NULL
, le SGBD va effectuer un test grâce à la condition logique. Celui-ci peut évenutellement être une condition avec des ordres SELECT...
Tester l'unicité d'une valeur
La clause UNIQUE
permet de vérifier que la valeur saisie pour un champ n'existe pas déjà dans la table. Cela permet de garantir que toutes les valeurs d'une colonne d'une table seront différentes.
R1 : Créez les tables correspondantes. L'ordre de création des tables doit être cohérent.
Correction
R2 : Ajoutez au moins un enregistrement par table. L’ordre des ajouts doit être cohérent.
Correction
R3 : Supprimez la clé primaire d’EXCEPTION. (puis remettez-la )
Correction
ALTER TABLE EXCEPTION
DROP FOREIGN KEY fk_trainExcep ;
ALTER TABLE EXCEPTION
DROP PRIMARY KEY ;
--Pour les remettre
ALTER TABLE EXCEPTION
ADD CONSTRAINT pk_exception PRIMARY KEY (numTrain, dateDep);
ALTER TABLE EXCEPTION
ADD CONSTRAINt fk_trainExcep FOREIGN KEY (numTrain) REFERENCES TRAIN(numTrain) ;
R4 : Ajoutez le tuple (‘5’, ‘Montparnasse’, ‘Paris’) dans GARE.
Correction
INSERT INTO gare (codeGare, nomGare, nomVille) VALUES
('5', 'Montparnasse', 'Paris');
R5 : Ajoutez deux trains partant de la gare ‘5’.
Correction
INSERT INTO train (numTrain, codeGareDep, CodeGareARR, HDep, HArr, CodeTrf) VALUES
('133', '5', '3', '2024-10-01 11:41:44', '2024-10-01 15:41:44', 'Q'),
('134', '5', '1', '2024-10-01 11:41:44', '2024-10-01 15:41:44', 'Q');
R6 : Modifiez le tuple (‘5’, ‘Montparnasse’, ‘Paris’)
en (‘5’, ‘Paris Montparnasse’, ‘Paris’)
, quelles sont les mises à jour à effectuer sur la base ?
Correction
UPDATE gare SET nomGare = 'Paris Montparnasse' WHERE gare.codeGare = 5;
R7 : Modifiez le tuple (‘5’, ‘Paris Montparnasse’, ‘Paris’)
en (‘15’, ‘Paris Montparnasse’, ‘Paris’)
, quelles sont les mises à jour à effectuer sur la base ?
Correction
Le point à noter ici est que le changement se fait sur la clé primaire. Or des enregistrements dans la table TRAIN
y sont lié.
Dans la méthode, il faudra mieux :
- Créer un nouvel enregistrement
(‘15’, ‘Paris Montparnasse’, ‘Paris’)
- Mettre à jour les enregistrements liés
- Supprimer l'enregistrement
(‘5’, ‘Paris Montparnasse’, ‘Paris’)
INSERT INTO gare (codeGare, nomGare, nomVille) VALUES
('15', 'Montparnasse', 'Paris');
UPDATE train SET codeGareDep = 15 WHERE codeGareDep = 5;
UPDATE train SET CodeGareARR = 15 WHERE CodeGareARR = 5;
DELETE FROM gare where codeGare = 5;
UPDATE gare SET gare.codeGare = 5 WHERE gare.codeGare = 15;
#1451 - Cannot delete or update a parent row: a foreign key constraint fails (`sncf`.`train`, CONSTRAINT `fk_gareDep` FOREIGN KEY (`codeGareDep`) REFERENCES `gare` (`codeGare`))
R8 : Créez un jeu de donnée pour des trains partant de Questembert. Puis modifiez les données pour que Tous les trains qui partent de Questembert soient de type quotidien.
Correction
INSERT INTO gare (codeGare, nomGare, nomVille) VALUES ('16', 'Questembert', 'Questembert');
INSERT INTO train (numTrain, codeGareDep, CodeGareARR, HDep, HArr) VALUES
('233', '16', '3', '2024-10-11 11:41:44', '2024-10-11 15:41:44'),
('234', '16', '1', '2024-10-21 11:41:44', '2024-10-21 15:41:44');
UPDATE train SET CodeTrf = 'Q' WHERE codeGareDep = 16 ;
R9 : Effacez tous les enregistrements de TRAIN qui partent de Rennes. On partiras du principe qu'il n'existe pas pas d'enregistrements liés dans les tables connexes.
Correction
DELETE from train WHERE ville ='Rennes' ;
R10 : Effacez tous les enregistrements de TRAIN. Quelles instructions complémentaires faut-il rajouter ?
Correction
DELETE FROM train ;
--Mais il faudra au préalable supprimer les enregistrements des tables COMPOSITION et EXCEPTION
DELETE FROM comosition ;
DELETE FROM exception ;