query matching mode
I have a simple table such as
I want to write a query to get the IDs based on codes. For example, I want to get the IDs if they have code 201 and 202. I can do it with the UNION function and id 1 and 2 will be returned.
But how can I find the IDs who has only codes: 201 and 202? That is, I want to get id 2 not 1 and 2.
Please advise me. Thanks,
from ( select id, code,
lag(code,1) over (partition by id order by code) prev_code1,
lead(code,1) over (partition by id order by code) next_code1,
lead(code,2) over (partition by id order by code) next_code2
where prev_code1 is null
and next_code2 is null
and next_code1 = 202
and code = 201
Click Here to Expand Forum to Full Width