Solved

Help with SQL Syntax - return all records of last date visited

Posted on 2009-07-09
9
242 Views
Last Modified: 2012-06-27
Without using TOP or ROW_NUMBER()  (because each person has a different record amount of times they visited) how can I return the last date visited.

EXAMPLE:
As of today July 09, 2009 , I would to look back at the last visited date and return all rows of records for their last date of visit.

VisitKey       Date of Service
    11            07/01/2009
    12            07/01/2009
    13            07/01/2009
    14            07/01/2009
    15            07/05/2009
    16            07/05/2009
    17            07/05/2009
0
Comment
Question by:Say55ow
  • 4
  • 4
9 Comments
 
LVL 59

Expert Comment

by:Kevin Cross
Comment Utility
Why would ROW_NUMBER() not work for you here?  Doesn't matter the number of records, if you ORDER BY date_of_service DESC and take row = 1 then will always be the last visit whether a person has one or a thousand visits.
0
 
LVL 59

Expert Comment

by:Kevin Cross
Comment Utility
If a person is represented by a visit key then would look something like this (can replace visit key with proper column for person id to get per person last date of service).
-- without row_number()

SELECT visitkey, max(date_of_service) as lastVisitDate

FROM your_table_name

GROUP BY visitkey;
 

-- with row_number()

SELECT visitkey, date_of_service as lastVisitDate

FROM (

   SELECT *, row_number() OVER(PARTITION BY visitkey ORDER BY date_of_service DESC) AS row

   FROM your_table_name

) a

WHERE a.row = 1;

Open in new window

0
 
LVL 39

Accepted Solution

by:
BrandonGalderisi earned 400 total points
Comment Utility
If your date of service does not have the time (datetime field with 00:00:00 time)....


select * from SomeTable
where Date_Of_Service = (select max(Date_Of_Service) from SomeTable)

Open in new window

0
 
LVL 17

Expert Comment

by:pssandhu
Comment Utility
It would be nice to see the table structure but letss assume you have a Person_ID, VistitKey, and DateVisited as your columns. To get all records for each person for thier last visit data you can do something like this:
Select  t.*
From   YourTable t INNER JOIN (Select Person_ID, MAX(DateVisited) From YourTable Group by Person_ID) l
             ON t.Person_ID = l.Person_ID
P.
0
Free Trending Threat Insights Every Day

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

 
LVL 39

Expert Comment

by:BrandonGalderisi
Comment Utility
After reading the question again, I believe I misread the requirement.
0
 
LVL 59

Assisted Solution

by:Kevin Cross
Kevin Cross earned 100 total points
Comment Utility
And I see now why this didn't make sense to me about row_number().  You want to pull back rows of data, the sample you gave is not finished product... :( I need to read better.

I would do this like Brandon showed or using INNER JOIN; however, slight syntax correction to what P. posted.
SELECT t.*

FROM your_table_name t

INNER JOIN (SELECT Person_ID, max(Date_Of_Service) AS max_DOS FROM your_table_name GROUP BY Person_ID) l

   ON t.Person_ID = l.Person_ID AND t.Date_Of_Service = l.max_DOS

Open in new window

0
 
LVL 59

Expert Comment

by:Kevin Cross
Comment Utility
LOL, it happens!
I still misread what you wrote Brandon.  Thought you nailed it.  Think you are just missing the link on user.
select * 

from SomeTable t1

where Date_Of_Service = (select max(Date_Of_Service) from SomeTable t2 where t2.person_id = t1.person_id)

Open in new window

0
 
LVL 39

Expert Comment

by:BrandonGalderisi
Comment Utility
you can always use dense_rank() instead of row_number().  Dense_Rank will return the same number for duplicate values.
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
Comment Utility
mwvisa1:

Yes.  That is what I was missing.  I used a subselect instead of a correlated subselect.
0

Featured Post

What is SQL Server and how does it work?

The purpose of this paper is to provide you background on SQL Server. It’s your self-study guide for learning fundamentals. It includes both the history of SQL and its technical basics. Concepts and definitions will form the solid foundation of your future DBA expertise.

Join & Write a Comment

In SQL Server, when rows are selected from a table, does it retrieve data in the order in which it is inserted?  Many believe this is the case. Let us try to examine for ourselves with an example. To get started, use the following script, wh…
This article explains how to reset the password of the sa account on a Microsoft SQL Server.  The steps in this article work in SQL 2005, 2008, 2008 R2, 2012, 2014 and 2016.
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.
When you create an app prototype with Adobe XD, you can insert system screens -- sharing or Control Center, for example -- with just a few clicks. This video shows you how. You can take the full course on Experts Exchange at http://bit.ly/XDcourse.

743 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now