Toon posts:

[MySQL] Join in combinatie met MAX

Pagina: 1
Acties:

Onderwerpen


Acties:
  • 0Henk 'm!

Anoniem: 123650

Topicstarter
Hallo,

Ik zit met de volgende gegevens.

Tabel a ( id, naam)
Tabel b (id, waarde_a, datum, opmerking)

Nu wil ik deze twee tabellen als volgt joinen in een query.

SELECT *
FROM a
INNER JOIN b ON b.waarde_a = a.id AND ...

Op de '...' zou ik graag een conditie willen hebben die ervoor zorgt dat ik een enkele regel uit tabel b haal en wel de regel met MAX(datum).

Heeft iemand een idee op welke manier dit meest effectief kan?

Alvast bedankt voor de moeite.

Acties:
  • 0Henk 'm!

  • Woy
  • Registratie: April 2000
  • Niet online

Woy

Moderator Devschuur®
Ik denk dat je op zoek bent naar een groupwise maximum. Op google is er genoeg over te vinden: [google=groupwise maximum]

“Build a man a fire, and he'll be warm for a day. Set a man on fire, and he'll be warm for the rest of his life.”


Acties:
  • 0Henk 'm!

  • Precision
  • Registratie: November 2006
  • Laatst online: 17-01-2020
Gecorreleerde subquery, een subquery met in de where clause een stuk van de originele query.
SELECT *
FROM a
INNER JOIN b ON b.waarde_a = a.id WHERE b.datum = ( select MAX(datum) from b as c where c.id = b.id )
zoiets geen idee of het werkt.

Niet goed wakker, oplossing die ik gaf, haalt het maximum op per rij en aangezien je een join gebruikt, heeft hij je alle waardes terug.
SELECT * FROM a INNER JOIN b ON b.waarde_a = a.id WHERE b.datum = ( select MAX(datum) from b )

[Voor 33% gewijzigd door Precision op 31-05-2011 15:28]

Crisis? Koop slim op Dagoffer - Op zoek naar een tof cadeau?



Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee