Assume the data in the table is as following:
1 2 3 4 | select fyr, age, type1 from ave107fa where paydat between '1041201' and '1041231' order by type1 ; |
data:image/s3,"s3://crabby-images/be920/be920c1c9ee76ddae9b224a3790c25e1945f3e5c" alt=""
We can find out the value of type1 has D and null.
If I would like to find the data which Type1 is not eqal to D:
1 2 3 4 5 | select fyr, age, type1 from ave107fa where paydat between '1041201' and '1041231' and type1 <> 'D' order by type1 ; |
But Oracle return nothing
:
data:image/s3,"s3://crabby-images/027df/027df740b158c3352eb6b72a55ed5168e831ad48" alt=""
How To
In Oracle, null represents a lack of data, a null cannot be equal or unequal to any value or to another null. Therefore, it will return nothing.
Hence, we can modify SQL statement as bellows:
1 2 3 4 5 | select fyr, age, type1 from ave107fa where paydat between '1041201' and '1041231' and nvl(type1, ' ') <> 'D' order by type1 ; |
The data which Type1 is null can be retrieved now:
data:image/s3,"s3://crabby-images/11ba5/11ba549955b1e32cb8d054c33a5e50bda9a5c6cf" alt=""
Reference
[1] https://docs.oracle.com/cd/B19306_01/server.102/b14200/sql_elements005.htm
No comments:
Post a Comment