首页数据库Oracle中判断数据类型是不是数字的方法有哪些

Oracle中判断数据类型是不是数字的方法有哪些

时间2024-03-23 09:00:03发布访客分类数据库浏览1156
导读:这篇文章主要给大家介绍“Oracle中判断数据类型是不是数字的方法有哪些”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Oracle中判断数据类型是不是数字的方法有哪些”文...
这篇文章主要给大家介绍“Oracle中判断数据类型是不是数字的方法有哪些”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Oracle中判断数据类型是不是数字的方法有哪些”文章能对大家有所帮助。

  

方法: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中判断数据类型是不是数字的方法有哪些内容,欢迎关注网络资讯频道,小编将为大家输出更多高质量的实用文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Oracle中判断数据类型是不是数字的方法有哪些
本文地址: https://pptw.com/jishu/651235.html
Oracle中ORDER BY排序方式有哪些,怎么实现 PHP8中match有什么表达性详解

游客 回复需填写必要信息