DELETE avec conditions sur plusieurs tables [Fermé]

Signaler
Messages postés
73
Date d'inscription
lundi 22 janvier 2018
Statut
Membre
Dernière intervention
24 février 2018
-
Messages postés
12613
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
14 octobre 2020
-
Bonjour,

J'essaye de faire un delete avec des conditions sur d'autres tables, mais je n'y arrive pas.

Pouvez-vous m'aider svp ?


DELETE (SELECT * FROM `orders_history` ORDER BY `Timestamp` DESC LIMIT 0,1)
WHERE (SELECT OrderType FROM getopenorders WHERE Exchange <> 'ORANGE') = ''
AND (SELECT OrderType FROM getorderhistory ORDER BY OrderType DESC LIMIT 0,1) = 'LIMIT_SELL'

1 réponse

Messages postés
12613
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
14 octobre 2020
701
bonjour, ce serait plutôt:
DELETE orders_history FROM orders_history, ...

montre-nous d'abord la requête qui te fournit les clés uniques des enregistrements que tu veux supprimer.
Messages postés
73
Date d'inscription
lundi 22 janvier 2018
Statut
Membre
Dernière intervention
24 février 2018

Bonjour,

Voici le select qui fonctionne. Mais je n'arrive pas à faire un DELETE sur cette ligne.

Vous pouvez m'aidez svp ?


SELECT * FROM orders_history as t1
WHERE exists (select 0 FROM getopenorders WHERE getopenorders.Exchange <> 'ORANGE' and getopenorders.exchange is not null)
AND exists (SELECT 1 FROM getorderhistory WHERE getorderhistory.OrderType = 'LIMIT_SELL' ORDER BY getorderhistory.TimeStamp DESC LIMIT 0,1)
AND t1.Type = 'buylimit'
order by t1.Timestamp DESC LIMIT 0,1
Messages postés
12613
Date d'inscription
lundi 9 juin 2008
Statut
Contributeur
Dernière intervention
14 octobre 2020
701 >
Messages postés
73
Date d'inscription
lundi 22 janvier 2018
Statut
Membre
Dernière intervention
24 février 2018

tu ne nous as pas donné la requête qui te fournit les clés uniques des enregistrements que tu veux supprimer. par ailleurs, ta requête me semble très suspecte, vu l’absence de jointure.
malgré tout, suggestion:
DELETE tdel
FROM orders_history as tdel, 
(SELECT cleunique FROM orders_history as t1
WHERE exists (select 0 FROM getopenorders WHERE getopenorders.Exchange <> 'ORANGE' and getopenorders.exchange is not null) 
AND exists (SELECT 1 FROM getorderhistory WHERE getorderhistory.OrderType = 'LIMIT_SELL' ORDER BY getorderhistory.TimeStamp DESC LIMIT 0,1)
AND t1.Type = 'buylimit'
order by t1.Timestamp DESC LIMIT 0,1) as tsrc
WHERE tdel.cleunique = tsrc.cleunique