您现在的位置是:网站首页> 编程资料编程资料
Oracle中判断字段是否为数字_oracle_
2023-05-27
453人已围观
简介 Oracle中判断字段是否为数字_oracle_
在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道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支持regexp_like函数,推荐使用正则的方式,如果不支持则用trim+translate这种方式。
您可能感兴趣的文章:
相关内容
- Oracle 函数大全_oracle_
- Oracle 中XML处理函数介绍_oracle_
- Oracle数据库中创建自增主键的实例教程_oracle_
- Oracle数据库中的级联查询、级联删除、级联更新操作教程_oracle_
- OracleOraDb10g_home1TNSListener服务无法启动怎么解决_oracle_
- Oracle用户连续登录失败次数限制如何取消_oracle_
- Oracle表空间查看sql使用情况_oracle_
- windows下oracle 11g r2 安装过程与卸载详细图解_oracle_
- 详解Oracle自定义异常示例_oracle_
- Oracle数学相关函数小结_oracle_
