AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL Befehl: erster und letzter Datensatz
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Befehl: erster und letzter Datensatz

Ein Thema von Angel4585 · begonnen am 27. Okt 2009 · letzter Beitrag vom 27. Okt 2009
Antwort Antwort
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#1

SQL Befehl: erster und letzter Datensatz

  Alt 27. Okt 2009, 20:10
Datenbank: MySQL • Version: 5 • Zugriff über: PHP
Hallo,

ich habe zwei Tabellen tab_users und tab_values.

In tab_users stehen Benutzerdaten drin wie zB uid und nickname.
In tab_values stehen werte zu den Benutzern drin welche stündlich eingetragen werden, das ganze mit nem zeitstempel.

Jetzt möchte ich mir den ersten und den letzten Datensatz zu jedem Benutzer innerhalb eines Zeitraumes ausgeben lassen.
Wie sollte da am besten das Statement aussehen?

Bisher hab ich nur das:

select * from tab_values where statetime>=$anfang and statetime <=$ende order by uid Also noch keinerlei Filter bzgl erster und letzter DS des Zeitraums.
Irgendwie muss das doch bestimmt mit den min und max Aggregatfunktionen gehen oder?

Ich komm irgendwie nich drauf
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: SQL Befehl: erster und letzter Datensatz

  Alt 27. Okt 2009, 20:12
min(starttime) und max(starttime)
Markus Kinzler
  Mit Zitat antworten Zitat
Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#3

Re: SQL Befehl: erster und letzter Datensatz

  Alt 27. Okt 2009, 20:20
ja schon, aber wie bring ich das im statement unter damit auch nur die beiden ds angezeigt werden?
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: SQL Befehl: erster und letzter Datensatz

  Alt 27. Okt 2009, 20:26
Eine Union könnte auch helfen
SQL-Code:
  select
    *
  from
    tab_values where statetime>=$anfang and statetime <=$ende
  group by
    uid
  order by
    starttime asc limit 1
union
  select
    *
  from
    tab_values where statetime>=$anfang and statetime <=$ende
    group by
    uid
  order by
    starttime desc limit 1;
Markus Kinzler
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: SQL Befehl: erster und letzter Datensatz

  Alt 27. Okt 2009, 21:26
Das geht auch schicker...

SQL-Code:
SELECT *
FROM tab_users u
INNER JOIN tab_values v
  ON u.uid = v.uid
WHERE statetime BETWEEN :anfang AND :ende
  AND ( statetime = (SELECT MIN(statetime)
                        FROM tab_values
                        WHERE uid = u.uid
                          AND statetime BETWEEN :anfang AND :ende)
        OR statetime = (SELECT MAX(statetime)
                        FROM tab_values
                        WHERE uid = u.uid
                          AND statetime BETWEEN :anfang AND :ende))
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:55 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz