{mysql} delete sur un select avec join..

Résolu
kalimbra Messages postés 546 Statut Membre -  
kalimbra Messages postés 546 Statut Membre -
Bonjour,

je me demandais s'il était possible de faire un delete sur un select sur la même table, mais jointé sur une autre table avec des conditions multiple ?

genre :

delete from Order_Line WHERE id_order IN (SELECT Order_Line.id_order_line FROM Order_Line LEFT JOIN session on Order_Line.id = session.id WHERE  Order_Line.id_order="985625421" AND (session.state = "closed" OR session.state ="inprogess" OR session.state="cancelled
"))
A voir également:

3 réponses

CaPiT Messages postés 622 Statut Membre 51
 
Bonjour.

Oui, c'est possible.

Au pire tu peux aussi faire un :
DELETE FROM table WHERE EXISTS (SELECT * ...)...
0
fiu
 
Salut

Méfie-toi quand même du left join : des lignes sont renvoyées même s'il n'y a pas de correspondance. et si tu supprimes les lignes renvoyées, tu supprimes tout.

le secret du delete : fais un select pour voir ce qui sera supprimé puis fais un delete avec strictement la même clause where
0
kalimbra Messages postés 546 Statut Membre 72
 
Oui au final comme j'avais une erreur à ma requete de delete sur la même table que le select j'ai fait deux requètes tant pis).

Pour économiser les requete en double je crée ma requète de delete via une boucle dans le select, je reconstitue le requète et je la passe..
0