在我們平常的開發(fā)中可能會遇到這樣的問題,就是判斷某一列是否全部由數(shù)字組成,我們都知道oracle并沒有給我們提供這樣一個(gè)現(xiàn)成的函數(shù),那么根據(jù)我的經(jīng)驗(yàn)我總結(jié)了兩個(gè)行之有效的方法(列名:column,表名:table):
1.使用trim+translate函數(shù):
復(fù)制代碼 代碼如下:
select * from table where trim(translate(column,'0123456789',' ')) is NULL;
這里要注意的是:translate函數(shù)的第三個(gè)參數(shù)是一個(gè)空格,不是'', 因?yàn)閠ranslate的第三個(gè)參數(shù)如果為空的話,那么永遠(yuǎn)返回'',這樣的就不能達(dá)到過濾純數(shù)字的目的。這樣把所有的數(shù)字都轉(zhuǎn)化為空格,如果全部是由數(shù) 構(gòu)成,那么一旦trim后自然是空,實(shí)現(xiàn)了上述目標(biāo)。當(dāng)然如果想排除空項(xiàng)的話,可以這樣寫:
復(fù)制代碼 代碼如下:
select * from table where trim(translate(nvl(column,'x'),'0123456789',' ')) is NULL;--x 表示任何'0-9'以外的字符。
2.使用regexp_like函數(shù):
復(fù)制代碼 代碼如下:
select * from table where regexp_like(column,'^[0-9]+[0-9]$');
這里要注意的是:regexp_like函數(shù)不是在所有的oracle版本中 都能使用的。regexp_like是oracle支持正則表達(dá)式的四個(gè)函數(shù):regexp_like,regexp_replace,regexp_instr,regexp_substr中的 一個(gè),有關(guān)這方面更加詳細(xì)信息,請關(guān)注相關(guān)文檔。
總結(jié)一下,如果oracle支持regexp_like函數(shù),推薦使用正則的方式,如果不支持則用trim+translate這種方式。
您可能感興趣的文章:- oracle刪除表字段和oracle表增加字段
- oracle使用sql語句增加字段示例(sql刪除字段語句)
- Oracle 插入超4000字節(jié)的CLOB字段的處理方法
- oracle關(guān)鍵字作為字段名使用方法
- 深入淺析mybatis oracle BLOB類型字段保存與讀取
- 簡單三步輕松實(shí)現(xiàn)ORACLE字段自增
- oracle數(shù)據(jù)庫中如何處理clob字段方法介紹
- Oracle 查詢表信息獲取表字段及字段注釋
- java讀寫oracle的blob字段示例
- ORACLE中段的HEADER_BLOCK示例詳析