• 技术文章 >数据库 >Oracle

    oracle怎么判断数据是否是数字类型

    长期闲置长期闲置2022-04-07 11:27:58原创1410

    方法:1、利用“trim(translate(column,'0123456789',' ')) is NULL;”判断数据是否是数字;2、利用“regexp_like(column,'^[0-9]+[0-9]$');”判断数据是否是数字。

    本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

    oracle怎么判断数据是否是数字类型

    select*from 表名 wherere 在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道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视频教程

    以上就是oracle怎么判断数据是否是数字类型的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:oracle
    上一篇:oracle怎么查询所有用户 下一篇:oracle怎么查询用户所有表
    PHP小白到大牛直播班第二十期

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 怎么关闭oracle trace日志• oracle怎么查询数据库中的所有表名• oracle怎么将数字转为字符串• 一起聊聊ORACLE中ORDER BY的多种排序• 总结分享Oracle日期函数
    1/1

    PHP中文网