方法:1、利用“trim(translate(column,'0123456789',' ')) is NULL;”判斷數(shù)據(jù)是否是數(shù)字;2、利用“regexp_like(column,'^[0-9]+[0-9]$');”判斷數(shù)據(jù)是否是數(shù)字。
本教程操作環(huán)境:Windows10系統(tǒng)、Oracle 11g版、Dell G3電腦。
oracle怎么判斷數(shù)據(jù)是否是數(shù)字類型
select*from 表名 wherere 在我們平常的開發(fā)中可能會遇到這樣的問題,就是判斷某一列是否全部由數(shù)字組成,我們都知道oracle并沒有給我們提供這樣一個現(xiàn)成的函數(shù),那么根據(jù)我的經(jīng)驗我總結(jié)了兩個行之有效的方法(列名:column,表名:table):
1.使用trim+translate函數(shù):
代碼如下:
select * from table where trim(translate(column,'0123456789',' ')) is NULL;
這里要注意的是:translate函數(shù)的第三個參數(shù)是一個空格,不是'', 因為translate的第三個參數(shù)如果為空的話,那么永遠(yuǎn)返回'',這樣的就不能達(dá)到過濾純數(shù)字的目的。
這樣把所有的數(shù)字都轉(zhuǎn)化為空格,如果全部是由數(shù) 構(gòu)成,那么一旦trim后自然是空,實(shí)現(xiàn)了上述目標(biāo)。當(dāng)然如果想排除空項的話,可以這樣寫:
代碼如下:
select * from table where trim(translate(nvl(column,'x'),'0123456789',' ')) is NULL;--x 表示任何'0-9'以外的字符。
2.使用regexp_like函數(shù):
代碼如下:
select * from table where regexp_like(column,'^[0-9]+[0-9]$');
這里要注意的是:regexp_like函數(shù)不是在所有的oracle版本中 都能使用的。
regexp_like是oracle支持正則表達(dá)式的四個函數(shù):regexp_like,regexp_replace,regexp_instr,regexp_substr中的 一個,有關(guān)這方面更加詳細(xì)信息,請關(guān)注相關(guān)文檔。
推薦教程:《Oracle視頻教程》