Oracle關(guān)于null的處理一直是數(shù)據(jù)庫(kù)開(kāi)發(fā)者頭疼的問(wèn)題之一,許多開(kāi)發(fā)者紛紛抱怨使用<=null會(huì)出現(xiàn)各種棘手的問(wèn)題。那么,究竟oracle中的<=null是什么意思,以及我們應(yīng)該如何正確使用呢?下面我們來(lái)詳細(xì)解釋。
首先,了解oracle的null值非常重要。null在oracle中表示“未知的值”或“不存在的值”,比如說(shuō),一個(gè)學(xué)生沒(méi)有分?jǐn)?shù),其分?jǐn)?shù)列的值便為空值。但是,在數(shù)據(jù)庫(kù)中處理null值時(shí),需要特別注意,否則就會(huì)產(chǎn)生一些棘手的問(wèn)題。
舉個(gè)例子,假設(shè)有一個(gè)表,其中的id列和value列都存在null值:
pre: CREATE TABLE test_table ( id NUMBER, value NUMBER ); INSERT INTO test_table (id, value) VALUES (1, null); INSERT INTO test_table (id, value) VALUES (2, 20); INSERT INTO test_table (id, value) VALUES (3, null); INSERT INTO test_table (id, value) VALUES (4, 30); INSERT INTO test_table (id, value) VALUES (5, 40); INSERT INTO test_table (id, value) VALUES (6, null); INSERT INTO test_table (id, value) VALUES (7, 50); INSERT INTO test_table (id, value) VALUES (8, null); INSERT INTO test_table (id, value) VALUES (9, 60); INSERT INTO test_table (id, value) VALUES (10, null);那么,我們來(lái)看看如果使用<=null語(yǔ)句進(jìn)行操作會(huì)發(fā)生什么:
pre: SELECT * FROM test_table WHERE value<= null;我們會(huì)得到一個(gè)空的結(jié)果集,這是因?yàn)閚ull無(wú)法與任何其他值進(jìn)行比較,所以結(jié)果只能是空的。而事實(shí)上,上述例子中,如果要找到null值,我們需要使用is null或is not null語(yǔ)句。例如:
pre: SELECT * FROM test_table WHERE value IS null;這樣,結(jié)果集就會(huì)包含id為1、3、6和8的四條記錄。
另外,如果我們想要查詢(xún)value列不為null的記錄,可使用is not null語(yǔ)句:
pre: SELECT * FROM test_table WHERE value IS NOT null;這樣,結(jié)果集就會(huì)包含id為2、4、5、7和9的五條記錄,因?yàn)檫@些記錄中value列都不為空。
綜上所述,oracle中的<=null表示“無(wú)效”,不能作為數(shù)據(jù)類(lèi)型,也無(wú)法做比較。要正確操作null值,需要使用is null或is not null等語(yǔ)句。在數(shù)據(jù)庫(kù)開(kāi)發(fā)中,注意處理null值是一個(gè)重要的問(wèn)題,需要特別小心。