加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 13:33:02 所属栏目:百科 来源:网络整理
导读:本文分别介绍使用trim+translate函数或regexp_like函数判断表中的某个字段是否为数字的方法 ? 1.使用trim+translate函数: select * from table where trim(translate(column,‘0123456789‘,‘ ‘)) is NULL; ? 这里要注意的是:translate函数的第三个参数

本文分别介绍使用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‘),‘ ‘)) 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中的 一个

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读