码迷,mamicode.com
首页 > 数据库 > 详细

Oracle中判断字段是否为数字

时间:2020-01-03 21:09:20      阅读:86      评论:0      收藏:0      [点我收藏+]

标签:没有   bst   pre   span   ike   ora   instr   文档   版本   

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

1.使用trim+translate函数:

select * from table where trim(translate(column,0123456789, )) is NULL;

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

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中的 一个,有关这方面更加详细信息,请关注相关文档。

Oracle中判断字段是否为数字

标签:没有   bst   pre   span   ike   ora   instr   文档   版本   

原文地址:https://www.cnblogs.com/lgx5/p/12146578.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!