Skip to content
Advertisement

Get TOP 1 row from multiple tables based on date

I have five tables in a SQL Server database. These tables are listed below and I want to select Data from these tables according to date. I tried searching but could not find solution for multiple tables. Please help

TABLE1

TABLE2

TABLE3

TABLE4

TABLE5

I want to select Label and Date from Table 3, 4 and 5 where Date is >1/1/2000 and < than and close to 24/10/2020 and grouped according to PId, CId, ConId and CNo.

Desired result:

Any help will be appreciated. Thank you.

Advertisement

Answer

You can achieve this with a couple of CTE’s; the first forms a UNION of TABLE3, TABLE4 and TABLE5; the second generates a row number based on the Date descending for each partition of PId, CId, ConId and CNo. We then select all rows from the second CTE where the row number is 1:

Output:

Demo on dbfiddle

User contributions licensed under: CC BY-SA
4 People found this is helpful
Advertisement