Solved

Query to delete rows

Posted on 2013-06-07
7
269 Views
Last Modified: 2013-06-13
I have a tabled defined as:

create table #YearlyTreatmentData(
 
  TreatmentYear int,
  EyeId nvarchar(18),
  TreatedWith nvarchar(30),
  TreatmentCount int );

Open in new window


The table holds the yearly treatment details for a patients with the type of treatment as TreatedWith, and the number of times treated that year with the treatment as TreatmentCount.

EyeId is a patient id.

I need a Query that will delete all the rows where a patient(EyeId) has been treated by anything other than the specific treatment i am interested in.

If i am looking for patients treated with PDT then i want to keep the patients that have ONLY been treated with PDT. The rest must be deleted.

Patients treated with something else, or patients that have been treated with PDT and something else must be deleted from the table.

I guess (using logic from my previous question) i must delete patients where the sum of all their treatments does not equal the sum of their treatments with PDT i.e. the patients that have changed treatment.

And then also delete every row that is not PDT i.e. the patients treated with something else-

Just dont know how to express this as a delete statement.

Thanks
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
7 Comments
 
LVL 19

Expert Comment

by:Bhavesh Shah
ID: 39228974
you mean to say this


delete from #table1
where TreatedWith <> 'PDT'
0
 
LVL 8

Expert Comment

by:didnthaveaname
ID: 39228980
delete from #YearlyTreatmentData
where
   treatedwith <> N'PDT';
0
 
LVL 8

Expert Comment

by:didnthaveaname
ID: 39228986
As a completely unrelated to the answer question, why don't you filter the inserts into the temp table based on the treatedwith column?
0
Edgartown IT Case Study

Learn about Edgartown's quest to ensure the safety and security of the entire town's employee and citizen data. Read the case study!

 

Author Comment

by:soozh
ID: 39229015
no that is not the answer!

Ofcourse i know how to delete patients that dont have PDT!

I need to delete patients that have PDT + something else, and all those that only have something else.

Your solution only deletes the second group - patients who have been treated with something else.

However i first need to delete patients that have changed treatment.
0
 
LVL 8

Accepted Solution

by:
didnthaveaname earned 167 total points
ID: 39229098
Is there only one treatedWith value per entry (will there be multiple rows with the same eyeID if they were treated with something else ) ?

Edit:

If yes, I think the following would work:

delete from YTD
from
   #YearlyTreatmentData as YTD
      left join #YearlyTreatmentData as YTDO on YTD.eyeID = YTDO.eyeID and YTDO.treatedWith <> YTD.treatedWith
   where
      YTDO.eyeID is not null or
      YTD.treatedWith <> N'PDT'; 

Open in new window


(if you have any sample data, that would be quite helpful for testing =))

Edit of Edit:

I changed the query to remove an extraneous filter.
0
 
LVL 32

Assisted Solution

by:awking00
awking00 earned 167 total points
ID: 39229184
delete from yearlytreatmentdata
where eyeid in
(select eyeid from
 (select eyeid from yearlytreatmentdata where treatedwith <> 'PDT')
 union
 (select eyeid from yearlytreatmentdata where treatedwith = 'PDT'
  intersect
  select eyeid from yearlytreatmentdata where treatedwith <> 'PDT')
);
0
 
LVL 41

Assisted Solution

by:Sharath
Sharath earned 166 total points
ID: 39229743
you can also try this.
DELETE FROM #yearlytreatmentdata t1 
WHERE  NOT EXISTS (SELECT 1 
                   FROM   #yearlytreatmentdata t2 
                   WHERE  t1.EyeId = t2.EyeId 
                   GROUP  BY t2.EyeId 
                   HAVING COUNT(DISTINCT t2.TreatedWith) = 1 
                          AND MAX(t2.TreatedWith) = 'PDT') 

Open in new window

0

Featured Post

Free Tool: Postgres Monitoring System

A PHP and Perl based system to collect and display usage statistics from PostgreSQL databases.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

'Between' is such a common word we rarely think about it but in SQL it has a very specific definition we should be aware of. While most database vendors will have their own unique phrases to describe it (see references at end) the concept in common …
If you find yourself in this situation “I have used SELECT DISTINCT but I’m getting duplicates” then I'm sorry to say you are using the wrong SQL technique as it only does one thing which is: produces whole rows that are unique. If the results you a…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used below. https://filedb.experts-exchange.com/incoming/2017/03_w12/1151775/Permutations.txt https://filedb.experts-exchange.com/incoming/201…

733 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