TP Commandes

TP Commandes

Ce TP intéractif s’exécute directement dans le navigateur… ou presque. Certaines questions sont “papier” et doivent être traitées à l’extérieur.

Chaque chargement de la page réinitialise vos requêtes, pensez à sauvegarder vos requêtes au fur et à mesure.

Ce TP couvre le programme… et le dépasse largement !

Première partie : Jean-Pierre Combani, un aventurier moderne. #

SuperDéco, un magasin souhaite augmenter son chiffre d’affaire. Pour cela ils envisagent d’améliorer l’enregistrement des commandes.

Ils souhaitent utiliser une base de donnée et font appel à vous (personne ne rit).

Voici leurs objectifs :

  • associer une commande à un client,
  • associer une commande à un vendeur,
  • enregistrer des clients et vendeurs homonymes,
  • connaître les dates, montant des commandes et mode de paiement,
  • recenser les adresses postales et mail de leurs clients,
  • connaître la position hierarchique et la date d’embauche des vendeurs.

Modèle relationnel #

Décrire un modèle relationnel permettant de réaliser cet objectif.

On n’oubliera pas les clés primaires et étrangères.

On peut répondre par un diagramme complet ou un schéma relationnel.

Conformité du modèle #

Voici les requêtes ayant servi à la construction des tables commande, client et vendeur.

CREATE TABLE "vendeur" (
	"id"	        INTEGER NOT NULL UNIQUE,
	"Nom"	        TEXT    NOT NULL,
	"Prenom"	    TEXT    NOT NULL,
	"Grade"	        INTEGER NOT NULL,
	"Embauche"	    TEXT    NOT NULL,
	PRIMARY KEY("id" AUTOINCREMENT)
);
CREATE TABLE "client" (
	"id"	        INTEGER NOT NULL UNIQUE,
	"Nom"	        TEXT    NOT NULL,
	"Prenom"	    NUMERIC NOT NULL,
	"Ville"	        TEXT    NOT NULL,
	"code_postal"	TEXT    NOT NULL,
	"Adresse"	    TEXT    NOT NULL,
	"email"	        TEXT,
	PRIMARY KEY("id" AUTOINCREMENT)
);
CREATE TABLE "commande" (
	"id"	        INTEGER NOT NULL UNIQUE,
	"id_vendeur"	INTEGER NOT NULL,
	"id_client"	    INTEGER NOT NULL,
	"montant"	    INTEGER NOT NULL,
	"reglement"	    TEXT    NOT NULL,
	"date"	        TEXT    NOT NULL,
	PRIMARY KEY("id"),
	FOREIGN KEY("id_client")  REFERENCES "client"("id"),
	FOREIGN KEY("id_vendeur") REFERENCES "vendeur"("id")
);
  1. Ce modèle est-il conforme à celui que vous avez retenu ? S’il y a des différences expliquez les.

Depuis que l’informaticien stagiaire non rémunéré est devenu influenceur, la base de donnée n’est plus enretenue.

Cinq ventes, présentées ci-dessous, ont été réalisées par le nouveau vendeur, Jean-Pierre Combani. Elles concernent de nouveaux clients.

Client Vendeur Date Paiment Montant
Durpet Micheline Combani Jean-Pierre 2022/04/19 Espèce 1234€
Siterne Frank Combani Jean-Pierre 2022/04/21 Chèque 3495€
Siterne Frank Combani Jean-Pierre 2022/05/02 Espèce 625€
Morteau Chaïna Combani Jean-Pierre 2022/05/12 Espèce 2455€
Siterne Frank Combani Jean-Pierre 2022/05/18 Espèce 75€
  1. Dans quel ordre saisir les éléments dans la base ? Justifier. On ne demande pas encore d’écrire de requêtes, seulement l’ordre.

Sélections simple #

  1. Écrire une requête permettant d’afficher tous les clients.
  2. Écrire une requête affichant les vendeurs triés par date de recrutement.
  3. Écrire une requête affichant les clients habitant Lille.

Sélections simples


Run Reset Download
Résultat

Modifications #

  1. Écrire une requête insérant le nouveau vendeur : Jean-Pierre Combani, recruté le 10 avril 2022, grade 2.
  2. Ajouter les clients Durpet Micheline et Siterne Frank habitant tous deux au 1, avenue des Fleurs à Lille, 59000 et d’emails respectifs cemimi@exemple.com et frankyyy@exemple.com. Ainsi que Morteau Chaïna, habitant 23, rue de la République à Lille, 59000: cjeje@exemple.com.
  3. Suite à des travaux réalisés par Jean-Pierre Combani dans la chambre du couple Durpet-Siterne, le couple s’est séparé. Modifier l’adresse de Siterne Frank qui a déménagé au 23 rue Basse à Lille.
  4. Vérifier tous les ajouts et modifications avec une ou plusieurs requêtes.

Modifications


Run Reset Download
Résultat

Requêtes complexes #

  1. Afficher toutes les numéros de commande, nom et prénom du client des commandes dont le montant dépasse 1000€.

  2. Afficher tous les clients (nom, prénom, email) ayant passé une commande à la vendeuse Kezac Annie.

  3. Écrire une requête affichant les commandes (nom & prénom du client, du vendeur, date, mode de paiement, montant) d’un montant qui dépasse 1000€.

  4. Ajouter les commandes du tableau précédent.

    On pourra commencer en utilisant les id des clients et du vendeur récupérées dans des requêtes préalables.

    Ensuite, pour pouvoir ajouter une commande en une requête n’utilisant que les noms du vendeur et du client il faut utiliser :

    INSERT INTO table
    SELECT (...);
    

    Par exemple :

    INSERT INTO table1 ( column1, column2, someInt, someString )
    SELECT  table2.column1, table2.column2, 8, 'some string etc.'
    FROM    table2
    WHERE   table2.ID = 7;
    

    Documentation : W3 Schools

Requêtes complexes


Run Reset Download
Résultat

Seconde partie : les ravages de Jean-Pierre Combani #

Un an s’est écoulé… Et de nombreuses commandes ont eu lieu. Les comptes de SuperDéco ne se sont guère améliorés mais, grace à la base de donnée ils peuvent enfin comprendre d’où vient le problème.

Jean-Pierre Combani a été licencié pour faute grave et un procès est en cours d’instruction. Il a diminué le montant de toutes ses commandes en espèce de 200€ afin de voler l’entreprise !

Il faut prévenir ses clients et rectifier les montants dans la base de donnée.

Modifications complexes #

  1. Afficher toutes les informations des clients de Jean-Pierre Combani (nom, prenom, adresse postale) ayant payé en espèce. Afin d’éviter les envois multiples de recommandés on retirera les doublons.

  2. Compter les commandes réglées en espèces à Jean-Pierre Combani. Calculer le total de ce qu’il a volé.

  3. Rectifier les montants des commandes frauduleuses dans la base de donnée.

Modifications complexes


Run Reset Download
Résultat