Jump to content

SQL Select mit Join und gruppieren


Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Empfohlene Beiträge

Hallo,
ich hab in SQL 2 Tabellen:

 

Tabelle 1: 

NR NAME
1    Mustermann

15  Mayr

33  Bacher
20  Max
 


Tabelle 2:
NR DATUM Status

1   14:00       1

15   14:00     1

1   15:00       1

33   11:00     1

15   17:30     1

33   15:00     1


Mein Select sieht nun so aus
Select 1.Nr, 1.Name, 2.Datum, 2.Status from Tabelle1 as 1 left join Tabelle2 as 2
on 1.NR = 2.NR
 

Als ergebniss bekomme ich jetzt natürlich mehrere Einträge pro NR da es ja mehrere Datums gibt.

Wie kann ich den select machen, das ich von der Tabelle 2 nur den letzten Eintrag (letztes Datum) retour bekomme?

Ergebniss sollte dann so aussehen
 

1 15:00 1
15 17:30 1
33 15:00 1
20 NULL NULL

 

DANKE


 


 

Link zu diesem Kommentar
  • 3 Wochen später...

mein Vorschlag:

komplett, zum nachvollziehen:

 

DECLARE @T1 AS TABLE(Nr INT, Name VARCHAR(50))

INSERT INTO @T1 SELECT 1,'Mustermann'

INSERT INTO @T1 SELECT 15 ,'Mayr'

INSERT INTO @T1 SELECT 33 ,'Bacher'

INSERT INTO @T1 SELECT 20 ,'Max'

DECLARE @T2 AS TABLE (Nr INT, Uhrzeit TIME, Status INT )

INSERT INTO @T2 SELECT 1,'14:00',1

INSERT INTO @T2 SELECT 15,'14:00',1

INSERT INTO @T2 SELECT 1,'15:00',1

INSERT INTO @T2 SELECT 33,'11:00',1

INSERT INTO @T2 SELECT 15,'17:30',1

INSERT INTO @T2 SELECT 33,'15:00',1

INSERT INTO @T2 SELECT 34,'19:00',1

 

SELECT * FROM @T1 t1

LEFT JOIN (SELECT Nr,MAX(Uhrzeit) Datum

FROM @T2

GROUP BY Nr) ua ON t1.nr=ua.Nr

 

SELECT * FROM @T1 t1

FULL JOIN (SELECT Nr,MAX(Uhrzeit) Datum

FROM @T2

GROUP BY Nr) ua ON t1.nr=ua.Nr

 

Nr Name          Nr        Uhrzeit
1   Mustermann 1         15:00:00

15 Mayr             15       17:30:00
33 Bacher          33       15:00:00
20 Max               NULL  NULL

 

 

Nr      Name            Nr Uhrzeit
1        Mustermann 1        15:00:00
15      Mayr             15      17:30:00
33      Bacher          33      15:00:00
20      Max              NULL  NULL
NULL NULL            34      19:00:00

bearbeitet von flyingmeniskus
Link zu diesem Kommentar
Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Schreibe einen Kommentar

Du kannst jetzt antworten und Dich später registrieren. Falls Du bereits ein Mitglied bist, logge Dich jetzt ein.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung jetzt entfernen

  Only 75 emoji are allowed.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor-Fenster leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

×
×
  • Neu erstellen...