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

Geschrieben

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


 


 

  • 3 Wochen später...
Geschrieben (bearbeitet)

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
Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Erstelle ein Benutzerkonto oder melde dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde dich hier an.

Jetzt anmelden
×
×
  • Neu erstellen...