Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Najnowsze rekordy, dla poszczególnych userów
Forum PHP.pl > Forum > Bazy danych > MySQL
kuubek
Witam
Chciałbym się zwrócić do szanownych kolegów o pomoc w rozwiązaniu takiego problemu.
Ogólnie chodzi o wizualizację danych z szybko rozrastającej się tabeli.
Tabela zapisuje zdarzenia:
Posiada kolumny oczywiście ID, lokalizacja_id, user_id, data.
Osób jest około 3000tyś lokalizacji około 30. Chodzi o to aby pokazywać najnowsze rekordy dla poszczególnych osób, aby można było stwierdzić w jakiej lokalizacji są.


  1. SELECT * FROM `location` WHERE (`lokation_id`,`data`)
  2. IN
  3. (
  4. SELECT `lokation_id`, MAX(`data`) FROM `location` GROUP BY `lokation`
  5. )



W zasadzie to zapytanie działa, ale przy małej ilości danych, niestety już przy kilkunastu tysiącach rekordów koszmar, może macie jakieś propozycję? Może jedno zapytanie, aha i jeszcze problem aby uzyskać dane z jenej lokalizacji(czyli kto aktualnie jest tam zarejestrowany)
pozdrawiam
reaktor
Mozna w ten sposob:

  1. SELECT l.lokalizacja_id, l.user_id, l.DATA
  2. FROM location l
  3. JOIN
  4. (
  5. SELECT max(DATA) AS maxdat, user_id FROM location GROUP BY user_id
  6. ) x
  7. ON l.user_id=x.user_id AND l.DATA=x.maxdat


Pamietaj tylko, ze w wynikach nie bedzie osoby ktora jeszcze nigdzie nie pojechala.
Drugi problem rozwiazesz prawie tak samo
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.