SQL - Requête suppression avec jointure

Résolu/Fermé
toxik56 Messages postés 12 Date d'inscription mercredi 2 juillet 2014 Statut Membre Dernière intervention 22 novembre 2014 - 4 juil. 2014 à 21:56
 kiko - 10 févr. 2021 à 14:24
Bonjour,

Je cherche actuellement à établir une requête suppression avec jointure mais je ne suis parvenu que partiellement à un résultat.

J'ai deux tables :
table1(NumContrat,X1,Y1,Z1)
table2(NumContrat,X2,Y2,Z2)

Ainsi, mon souhait serait de supprimer dans table1 tous les contrats qui figurent dans table1 et table2.

J'ai établi le code SQL suivant :

DELETE *
FROM table1
WHERE Table2.NumContrat = Table1.NumContrat ;

Seulement, j'ai créé un programme où c'est à moi de définir les lignes à supprimer en indiquant les numéros de contrat..

Je vous remercie par avance pour votre aide.

Cdt

3 réponses

toxik56 Messages postés 12 Date d'inscription mercredi 2 juillet 2014 Statut Membre Dernière intervention 22 novembre 2014 4
6 juil. 2014 à 23:22
Merci beaucoup pour ta réponse Morgothal !

Je viens de tester ta solution. Du fait qu'il y a deux attributs "NumContrat" respectivement dans table1 et table2, la requête bloque à la ligne 3. Il ne comprend pas de quelle table on parle malgré le FROM en ligne 4. Bref', le code marche parfaitement hormis ce détail, merci infiniment !

Pour ceux qui tomberaient sur ce topic, voici le code que je retiendrais :

DELETE * FROM table1
WHERE NumContrat in
(SELECT table1.NumContrat
FROM table1 INNER JOIN table2 ON table1.NumContrat = table2.NumContrat)

Cdt
3
Morgothal Messages postés 1235 Date d'inscription jeudi 22 avril 2010 Statut Membre Dernière intervention 19 mai 2015 179
7 juil. 2014 à 12:26
Oui c'est tout à fait ce qu'il faut faire :)
Bien joué

A+
0
albamak Messages postés 1 Date d'inscription lundi 7 juillet 2014 Statut Membre Dernière intervention 7 juillet 2014
7 juil. 2014 à 15:49
ce exilent, ta réponse Morgothal
0
merci beaucoup j'ai pu solutionner mon problème après de nombreuses recherches
0
merciiiiiiiiiiiiiiiiiiiiiiiiiiiiiii bcp
0