reminett Skrevet 14. desember 2015 Del Skrevet 14. desember 2015 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
Enthroner Skrevet 16. desember 2015 Del Skrevet 16. desember 2015 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
Anbefalte innlegg
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 kontoLogg inn
Har du allerede en konto? Logg inn her.
Logg inn nå