Avatar billede rotco Juniormester
14. februar 2014 - 18:55 Der er 3 kommentarer

PHP while loop og begrænsning (mysql)

Hejsa,

Jeg har en tabel hvor der er en masse rækker. Nogle af rækkerne er dog skrevet af den samme person (medlems_id). Jeg kunne godt tænke mig at trække én række ud per bruger. Dvs. at hvis der er flere der er skrevet af det samme ID, så er det kun den sidste række der bliver skrevet sorteret efter timestamp.

$query = mysql_query("SELECT * FROM indlaeg ORDER BY timestamp DESC");       
while($row = mysql_fetch_assoc($query)){
echo $row['titel'];
}

Det vil altså sige at hvis jeg har 10 brugere, der har skrevet 30 artikler tilsammen, så bør der reelt set kun blive udskrevet 10 rækker, hvor det seneste indlæg fra hver bruger bliver vist.
Avatar billede arne_v Ekspert
14. februar 2014 - 18:57 #1
maaske:

SELECT *
FROM indlaeg i1
WHERE timestamp = (SELECT MAX(timestamp) FROM indlaeg i2 WHERE i2.bruger = i1.bruger)
ORDER BY timestamp DESC
Avatar billede arne_v Ekspert
14. februar 2014 - 18:58 #2
Er timestamp ikke et reserveret ord i MySQL?
Avatar billede arne_v Ekspert
14. februar 2014 - 19:00 #3
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester