Oracle中判断字段是否为数字

在咱们日常的开发中可能会遇到这样的问题,就是判断某一列是否所有由数字组成,咱们都知道oracle并无给咱们提供这样一个现成的函数,那么根据个人经验我总结了两个行之有效的方法(列名:column,表名:table):html

1.使用trim+translate函数:正则表达式

 

复制代码代码以下:
select * from table where trim(translate(column,'0123456789',' ')) is NULL;

 

  这里要注意的是:translate函数的第三个参数是一个空格,不是'', 由于translate的第三个参数若是为空的话,那么永远返回'',这样的就不能达到过滤纯数字的目的。这样把全部的数字都转化为空格,若是所有是由数 构成,那么一旦trim后天然是空,实现了上述目标。固然若是想排除空项的话,能够这样写:oracle

 

复制代码代码以下:
select * from table where trim(translate(nvl(column,'x'),'0123456789',' ')) is NULL;--x 表示任何'0-9'之外的字符。

 

2.使用regexp_like函数:函数

 

复制代码代码以下:
select * from table where regexp_like(column,'^[0-9]+[0-9]$');

 

  这里要注意的是:regexp_like函数不是在全部的oracle版本中 都能使用的。regexp_like是oracle支持正则表达式的四个函数:regexp_like,regexp_replace,regexp_instr,regexp_substr中的 一个,有关这方面更加详细信息,请关注相关文档。post

转载于:https://www.cnblogs.com/forzheng/p/8398999.htmlspa