[SQL] Suppression en "cascade"

Fermé
patrice86 Messages postés 1378 Date d'inscription dimanche 26 octobre 2008 Statut Membre Dernière intervention 26 novembre 2023 - Modifié par patrice86 le 16/11/2011 à 18:34
patrice86 Messages postés 1378 Date d'inscription dimanche 26 octobre 2008 Statut Membre Dernière intervention 26 novembre 2023 - 16 nov. 2011 à 19:51
Bonjour,

Je disposes d'une BDD avec des clients, des commandes...

Lorsque je supprime un client de la BDD, je souhaiterai que automatiquement soit supprimer toute les commandes effectuées par ce client.

Voici la création des tables:
CREATE TABLE personnes
(
num_pers serial NOT NULL,
nom_pers character varying(20) NOT NULL,
prenom_pers character varying(20) NOT NULL,
fix_pers integer,
port_pers integer,
rue_pers character varying(30),
cp_pers integer,
ville_pers character varying(20),
mail character varying(15),
CONSTRAINT personnes_pkey PRIMARY KEY (num_pers )
)

CREATE TABLE commandes
(
num_com serial NOT NULL,
total_com integer,
numpers_com integer NOT NULL,
CONSTRAINT pk_commandes PRIMARY KEY (num_com ),
CONSTRAINT fk_commandes FOREIGN KEY (numpers_com)
REFERENCES personnes (num_pers)
)

Les tables sont donc liées par num_pers, maintenant restes à savoir comment faire la suppression automatique dans commandes.

Merci de votre aide.



2 réponses

jee pee Messages postés 39615 Date d'inscription mercredi 2 mai 2007 Statut Modérateur Dernière intervention 23 avril 2024 9 230
16 nov. 2011 à 18:44
Salut,

Il faudrait que tu précises le sgbd que tu utilises car les techniques varient.

Pour Oracle cela ce situe au niveau du create table, voir : https://www.techonthenet.com/oracle/foreign_keys/foreign_delete.php

cdlt
0
patrice86 Messages postés 1378 Date d'inscription dimanche 26 octobre 2008 Statut Membre Dernière intervention 26 novembre 2023 125
Modifié par patrice86 le 16/11/2011 à 19:04
J'utilise une bdd sous postgre
J'ai essayé en faisant
CREATE TABLE commandes
(
num_com serial NOT NULL,
total_com integer,
numpers_com integer NOT NULL,
CONSTRAINT pk_commandes PRIMARY KEY (num_com ),
CONSTRAINT fk_commandes FOREIGN KEY (numpers_com)
REFERENCES personnes (num_pers) ON DELETE CASCADE
)

mais lorsque je veux ajouter une commande en sql:
insert into commandes values(default, 3000,6);

j'ai un jolie message d'erreur:
ERREUR: une instruction insert ou update sur la table « commandes » viole la contrainte de clé
étrangère « fkpers_com »
DETAIL: La clé (numpers_com)=(6) n'est pas présente dans la table « personnes ».
0
jee pee Messages postés 39615 Date d'inscription mercredi 2 mai 2007 Statut Modérateur Dernière intervention 23 avril 2024 9 230
16 nov. 2011 à 19:46
Il est évident que l'enregistrement de la table personne doit exister avant de pouvoir créer une commande;
0
patrice86 Messages postés 1378 Date d'inscription dimanche 26 octobre 2008 Statut Membre Dernière intervention 26 novembre 2023 125
16 nov. 2011 à 19:51
Il existe bien.
L'enregistrement avec pour num_pers = 6 existe.
je ne comprends pas
0