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!

Recommended Posts

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 to post
  • 3 weeks later...

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

Edited by flyingmeniskus
Link to post
Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...