sql >> Database >  >> RDS >> Sqlserver

De meest recente records binnen een query ophalen

MySQL heeft geen ranking/analytische/windowing functionaliteit.

SELECT tl.locationid, tl.timestamp, tp.name, X, Y, Z
  FROM tblPerson tp
  JOIN tblLocation tl ON tl.personid = tp.personid
  JOIN (SELECT t.personid,
               MAX(t.timestamp) AS max_date
          FROM tblLocation t
      GROUP BY t.personid) x ON x.personid = tl.personid
                            AND x.max_date = tl.timestamp

SQL Server 2005+ en Oracle 9i+ ondersteunen analyses, dus u kunt het volgende gebruiken:

SELECT x.locationid, x.timestamp, x.name, x.X, x.Y, x.Z
  FROM (SELECT tl.locationid, tl.timestamp, tp.name, X, Y, Z,
               ROW_NUMBER() OVER (PARTITION BY tp.name ORDER BY tl.timestamp DESC) AS rank
          FROM tblPerson tp
          JOIN tblLocation tl ON tl.personid = tp.personid) x
WHERE x.rank = 1

Een variabele gebruiken om dezelfde ROW_NUMBER-functionaliteit op MySQL te krijgen:

SELECT x.locationid, x.timestamp, x.name, x.X, x.Y, x.Z
  FROM (SELECT tl.locationid, tl.timestamp, tp.name, X, Y, Z,
               CASE
                 WHEN @name != t.name THEN
                   @rownum := 1
                 ELSE @rownum := @rownum + 1
               END AS rank,
               @name := tp.name
          FROM tblLocation tl
          JOIN tblPerson tp ON tp.personid = tl.personid
          JOIN (SELECT @rownum := NULL, @name := '') r
      ORDER BY tp.name, tl.timestamp DESC) x
WHERE x.rank = 1


  1. SQL Server 2005 herstelt slechts één schema

  2. Echo JS onclick vulfunctie AJAX werkt niet

  3. PostgreSQL-vastleggroep voor reguliere expressies in select

  4. Zijn PL/pgSQL en SQL in PostgreSQL beide op hetzelfde niveau als de SQL/PSM-standaard, in plaats van alleen als SQL-standaard?