Gå til innhold

Slette alle duplikater i tabell


Anbefalte innlegg

Heisann, godtfolk!

Mulig denne hører bedre hjemme i database-forumet, men jeg vil anta at dette er enklest å gjøre i PHP.

 

Jeg ønsker å slette alle duplikater i tabellen min, utenom den som har den siste timestampen.

 

NAVN   ADRESSE       POSTNR   TIMESTAMP

 

Ola       Hjemmevn. 1   1234          645531531

Ola       Hjemmevn. 1   1234          432524542

Ola       Hjemmevn. 1   1234          233213124

 

 

 

Her ønsker jeg altså å slette de to nederste fordi NAVN, ADRESSE og POSTNR er identiske.

 

Setter pris på tilbakemelding dersom det er noen her som vet hvordan jeg kan automatisere dette gjennom hele tabellen min.

 

Remi

Lenke til kommentar
Videoannonse
Annonse

Du grupperer basert på de radene som skal være unike. Så setter du en ID tilsvarende maks timestamp, og lager en join. Alle som ikke har fått RowId er duplikater.

DELETE TabellenMin 
FROM TabellenMin
LEFT OUTER JOIN (
   SELECT MAX(TIMESTAMP) as RowId, NAVN, ADRESSE, POSTNR 
   FROM TabellenMin 
   GROUP BY NAVN, ADRESSE, POSTNR
) as BeholdRader 
ON
   TabellenMin.RowId = BeholdRader.RowId
WHERE
   BeholdRader.RowId IS NULL
Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
×
×
  • Opprett ny...