oracle判断表中的某个字段是否为数字

Posted thomasbc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle判断表中的某个字段是否为数字相关的知识,希望对你有一定的参考价值。

本文分别介绍使用trim+translate函数或regexp_like函数判断表中的某个字段是否为数字的方法

 

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判断表中的某个字段是否为数字的主要内容,如果未能解决你的问题,请参考以下文章

sql 如何判断表中的某个字段是不是有某个值

day05_oracle各种约束示例

oracle判断表是不是存在字段

用oracle如何查询出一个表中的一个字段内容包含另一个表中的某个字段的值呢

oracle有没有方法把数据库表中的字段的所有数据中的某个字母或数字修改或替换

如何查出在oracle 表中的某个字段中符合以下要求:包括除汉字、数字、字母、中画线、括弧外的其它字符