zoukankan      html  css  js  c++  java
  • oracle判断表中的某个字段是否为数字trim+translate函数或regexp_like函数

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

  • 相关阅读:
    Linux基本命令
    LR之流程
    Jmeter&Ant构建自动化测试平台
    正则表达式
    搭建wordpress-安装xshell
    git本地文件提交
    Git基本操作
    python-之基本语法
    SQL语句之-简单查询
    postman之请求&断言
  • 原文地址:https://www.cnblogs.com/thomasbc/p/9225731.html
Copyright © 2011-2022 走看看