Skip to Main Content

SQL & PL/SQL

Announcement

For appeals, questions and feedback about Oracle Forums, please email oracle-forums-moderators_us@oracle.com. Technical questions should be asked in the appropriate category. Thank you!

Interested in getting your voice heard by members of the Developer Marketing team at Oracle? Check out this post for AppDev or this post for AI focus group information.

Find missing numbers in a specific numeric field for all rows

clarcombeApr 27 2010 — edited Apr 25 2013
In a table, there is a numeric field which contains an inexhaustive list of values
e.g. 1,2,3,5,9,13.

Is there a way to list all values which are NOT in the list using an SQL Query (not cursor)

i.e. 4,6,7,8,10,11 etc

The solution so far is to generate the existing value + 1 ensuring that it is not in the list.

SELECT DISTINCT e1_cd_aff + 1 AS NUMINDEX

FROM affair_raw_ref

WHERE e1_cd_aff + 1 NOT IN

(SELECT DISTINCT e1_cd_aff FROM affair_raw_ref))


But for example this would only retrieve 6 between 5 and 9 but not 7 or 8.

Any suggestions

Thanks

Colin Larcombe

Comments

Processing
Locked Post
New comments cannot be posted to this locked post.

Post Details

Locked on May 23 2013
Added on Apr 27 2010
5 comments
3,240 views