Tricky Triple Sql Join While finding the most recent date

left outer join
sql join multiple tables with conditions
postgres update join multiple tables
how to join 4 tables in sql query
sql join 3 tables
postgresql join multiple tables
left join 3 tables
mysql inner join

I apologize if this question has been asked in a similar way before. I am rather new to SQL and am having a very difficult time finding the solution to my problem. Very confused.

I currently have three tables:

Templates - | id | name |

Users - | id | full_name |

Changelog - | id | id_user | id_template | last_edited_at

I have a table filled with templates.

I have a separate table full of users WHO make changes on those templates. Every time a change is made, an entry is created in the changelog table.

I am trying to create a query with the main goal being fetching EVERY record from templates, as well as WHEN it was most recently changed, and BY WHOM.

I came up with this query which allows me to find the most recent change for a specific template ID.

SELECT changelogs.id_user, changelogs.updated_at, users.full_name
FROM changelogs
JOIN users
ON changelogs.id_user =
WHERE changelogs.id_template = :templateId
ORDER BY changelogs.updated_at DESC 

I orignally tried to solve this problem by looping through each template record, and running the above query for each record ID, but that is slow and doesn't work. I know there must be a way to do this in SQL, and I wanted to see if anybody has solved a similar problem. I didn't design this database, so sorry if it is not optimized.

My ideal final result would be a table that looks like:

| | | | changelog.updated_at |

Thanks so much in advance for any guidance

You can use two JOINs to get the information from all the tables and then use a SUBQUERY to get the maximum value for the updated_at field, like this:

SELECT as template_id, as template_name, as user_name, 
    c.updated_at as changelog_updated_at 
    changelogs c

INNER JOIN templates t on c.id_template =
INNER JOIN users u on c.id_user =

  c.updated_at = 
    (SELECT MAX(updated_at) FROM changelogs c2 where c2.id_template =

ORDER BY t.template_name 

Understanding Tricky Joins and Multi-Table Updates in PostgreSQL , Writing a proper SQL UPDATE query involving multiple tables in Postgres can be tricky and counterintuitive. This stems from the fact that when performing an UPDATE, other An inner join is performed, then a new row is added for each such as the date of the last email correspondence with an entity. If you can have two instances of a course starting on the same date, then you’ll need the auto_increment. For the query, I’ve listed all courses, and their most recent start date, if they’ve

You can use a correlated subquery:

SELECT cl.id_user, cl.updated_at, u.full_name
FROM changelogs cl JOIN
     users u
     ON cl.id_user =
WHERE cl.updated_at = (SELECT MAX(cl2.updated_at)
                       FROM changelogs cl2
                       WHERE cl2.id_template = cl.templateId

For each template referred to in the outer query the subquery finds the maximum update date. This is then used to filter the records in the outer query.

How to join three tables in SQL query – MySQL , Joining multiple tables in SQL is always a tricky task, It can be more difficult if you need SQL Joins have always been tricky not only for new programmers but for Here is a general SQL query syntax to join three or more table. Let us know if you face any issue while running this 3 table JOIN query in any other database. A common query that crops up in web apps is finding the oldest or the most recent record in a single table. This is straightforward in SQL. You can even write the relevant part of the query without knowing anything about the table (other than the fact that it has a timestamp column called created_at):

I think a window function is your friend here. I didn't spin up sample tables to run this on, so there my be a type-o or two:

select *
from (

    select *
        ,row_number() over (partition by order by c.last_edited_at desc) row
        from Templates t
        left join ChangeLog c
        left join Users u

) t
where row=1

Billboard, BUN'S BACK Bun B has set an April 29 release date for his second solo New material will be featured at a handful of upcoming U.S. shows, including "​executive vision and direction," says he was floored when he first dropped by Those three plus pop act Wonder Girls join Park on JYP's American tour that began Feb. 10 SQL Tricks That You Didn’t Think Were Possible Posted on April 25, 2016 March 9, 2020 by lukaseder Listicles like these do work – not only do they attract attention, if the content is also valuable (and in this case it is, trust me), the article format can be extremely entertaining.

Learning PHP, MySQL, and JavaScript: A Step-By-Step Guide to , example of SQL (which stands for “Structured Query Language”), a language For example, you can join multiple tables according to various criteria, ask for part of the string that you are searching for, return only the nth result, and a lot more. in front of your eyes rather than when a new page is returned by the server. Without a doubt, and most of the time, we need a result set that is formed combining data from several tables. The joins allow us to combine data from two or more tables so that we are able to join data of the tables so that we can easily retrieve data from multiple tables. You might ask yourself how many different types of join exist in SQL

SQL Joins Tricky Interview Questions, This is the most basic and common interview scenario where interviewer asked the outcome of query containing either Inner SQL Join or Left  The most common syntax for performing a join is T1 <JOIN TYPE> T2 ON <expression>, where T1 and T2 are tables, and expression is the join condition which determines if a row in T1 and a row T2 “match.” JOIN TYPE can be one of the following (words in square brackets are optional), each generating a different result set:

Farm Journal, CORN FLAKES Oven-fresh always Inner-sealed waxtite wrapper keeps after opening as Kellogg's as fresh, and cris All golden brown—just packed with health when The hostess blindfolds each guest as he joins the others and those who Telling the mystery story is an old trick in a new dress, but your guests may not  Surprisingly, given the sample data provided, the result of this query will be an empty set. The reason for this is as follows: If the set being evaluated by the SQL NOT IN condition contains any values that are null, then the outer query here will return an empty set, even if there are many runner ids that match winner_ids in the races table.

  • Wasn't me, only thing I noticed with this solution is that a template that was never changed isn't included. If the creation isn't included in the ChangeLog table.
  • @EdCallahan . . . Doesn't seem likely because the accepted answer also assumes that all templates are in the changelog.
  • I just noticed I was down-voted too. Whatever, how do you down-vote the use of a window function? They are simply cool. ;)
  • @EdCallahan is there anyway to run that window function (with row_number) or similar in MySQL, I can't get your query to run and I would like to set up a query that also includes templates that haven't been changed for another part of my project