Solved

Query to delete patients last visit.

Posted on 2013-06-09
3
222 Views
Last Modified: 2013-07-01
I have a table that contains a list of patient id's and visit years .  For example:

PatientID  VisitYear
A1              1
A1              2
A1              2
A1              3
A1              3
A2              1
A2              2
A2              2
A3              1

Open in new window


I need Query that will delete ALL the entries for the patients last year.  So the above table would look like

PatientID  VisitYear
A1              1
A1              2
A1              2
A2              1

Open in new window

0
Comment
Question by:soozh
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
3 Comments
 
LVL 22

Expert Comment

by:Thomasian
ID: 39233145
DECLARE @t TABLE (PatientID varchar(10), VisitYear int)

INSERT @t
SELECT 'A1', 1
UNION ALL SELECT 'A1', 2
UNION ALL SELECT 'A1', 2
UNION ALL SELECT 'A1', 3
UNION ALL SELECT 'A1', 3
UNION ALL SELECT 'A2', 1
UNION ALL SELECT 'A2', 2
UNION ALL SELECT 'A2', 2
UNION ALL SELECT 'A3', 1

DELETE T
FROM
	(SELECT  rn=RANK() OVER (PARTITION BY PatientID ORDER BY VisitYear DESC)
	 FROM @t
	) T
WHERE rn=1

SELECT * FROM @t

Open in new window

0
 
LVL 41

Assisted Solution

by:Sharath
Sharath earned 250 total points
ID: 39233880
Another method.
delete t1
  from YourTable t1
  join (select PatientID,max(VisitYear) VisitYear from YourTable group by PatientID) t2
    on t1.PatientID = t1.PatientID and t1.VisitYear = t2.VisitYear

Open in new window

0
 
LVL 32

Accepted Solution

by:
awking00 earned 250 total points
ID: 39237783
delete from yourtable as a
where exists
(select b.patientid, max(b.visityear)
 from yourtable as b
 group by b.patientid
 having b.patientid = a.patientid
    and max(b.visityear) = a.visityear);
0

Featured Post

Get 15 Days FREE Full-Featured Trial

Benefit from a mission critical IT monitoring with Monitis Premium or get it FREE for your entry level monitoring needs.
-Over 200,000 users
-More than 300,000 websites monitored
-Used in 197 countries
-Recommended by 98% of users

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

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.
This article describes how to use the timestamp of existing data in a database to allow Tableau to calculate the prior work day instead of relying on case statements or if statements to calculate the days of the week.
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

734 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