Jump to content

Recommended Posts

hi, i was given this situation

 

SQL Test: Imagine you have a User table for a twitter-like web application that looks like this: Username, Status Update, Date Updated          (eg. Ann123, "Hi, I am at Startbucks!", 01/26/12 10:00:01). Write a query that selects only the latest status update for each user.

 

and so I created my own dummy table to test what I thought would be the answer

 

CREATE TABLE USER( 
id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
username VARCHAR(50),
`status` VARCHAR(50),
`dateupdated` DATETIME
) ENGINE = INNODB;  

 

then I ended up with this query

 

SELECT user.`username`, latest.status AS latest_status , user.`dateupdated` FROM USER LEFT JOIN USER AS latest ON user.`id` = latest.id ORDER BY dateupdated 

 

but it seem like it's still wrong, since I used an ID as primary key, the username can be repeated  and the question scenario should only give the unique latest update for each user, "I think" ...any suggestions how to fix this problem ?

 

Link to comment
https://forums.phpfreaks.com/topic/257904-self-join-plus-limit-unique/
Share on other sites

First of all you do not want a LEFT JOIN.  A LEFT JOIN is really shorthand for an "outer" join, where you will get a row for every row in the "LEFT" table.  In this case the left table is going to be the table named in the FROM clause.  What you actually want is an inner join, which in terms of shorthand, is simply a "JOIN".

 

It's always useful in these problems to break things down into individual queries.  Start with how you would get the most recent "dateupdated' for each username?

 

SELECT username, MAX(dateupdated) as dateUpdated
FROM USER
GROUP BY username

 

So it's clear in this case, that to pull a single row out, you need to match both the username and the MAX(dateupdated) result from the GROUP BY.  You can do this by aliasing the query and then joining to it.

 

SELECT id, u.username, status, u.dateupdated 
FROM USER u 
JOIN 
(SELECT username, MAX(dateupdated) as dateupdated FROM USER GROUP BY username)  ul 
ON u.username = ul.username AND u.dateupdated = ul.dateupdated; 

 

 

 

 

This thread is more than a year old. Please don't revive it unless you have something important to add.

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.   Restore formatting

  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...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.