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

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

浏览次数:1666次
信息来源: 银河系资源网
更新日期: 2022-05-14
文章简介

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

方法: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怎么判断数据是否是数字类型的详细内容

标签: 暂无标签
oracle怎么查询用户所有表
« 上一篇
oracle怎么查询所有用户
下一篇 »
  • oracle怎么查询数据库中的所有表名
    811172阅读
    查询方法:1、使用“SELECT * FROM all_tables WHERE OWNER = '用户名'”语句,可查询指定用户的所有表名;2、使用“SELECT * FROM user_tables”语句,可查询当前用户的所有表名。本教程操作环境:Windows7...
  • 总结MySQL常见错误分析与解决方法
    79852阅读
    免费学习:mysql教程一、Can’t connect to MySQL server on ‘localhost’ (10061) 翻译:不能连接到 localhost 上的mysql 分析:这说明“localhost”计算机是存在的,但在这台机器上却没提供MySQL服务。 需要启动这...
  • mysql怎么查询第一列数据
    2475阅读
    在mysql中,可以利用SELECT语句来查询第一列数据,该语句可以根据指定列的字段名来查询数据并输出结果,只需要将“SELECT”关键字后面的字段名设置为需要查找的第一列字段名即可; 语法“SELECT 第一列字段名 FROM 表...
  • oracle怎么查询clob字段数据
    1875阅读
    在oracle中,可以利用instr()函数配合select语句查询clob字段数据,instr函数用于判断字符串是否含有指定的字符,语法为“select*from 表名 ...instr(字段名(clod类型),'查询条件',1,1)”。本教程操作环境:...
  • mysql主从同步如何跳过错误
    1816阅读
    mysql主从同步跳过错误的方法:1、跳过指定数量的事务,代码为【mysql>SET GLOBAL SQL_SLAVE_SKIP..】;2、修改mysql的配置文件,通过【slave_skip_errors】参数来跳所有错误。本教程操作环境:windows7系统、mysql ...
  • mysql workbench是什么意思
    1660阅读
    mysql workbench是管理MySQL数据库工具的意思,是一款专门为mysql设计的集成化桌面软件;该软件同时具有开源社区版和收费商业版两个版本,主要用于设计和创建新的数据库图示、建立数据库文档以及进行复杂的mysql迁移...
  • 实例详解oracle添加唯一约束
    1635阅读
    本篇文章给大家带来了关于Oracle的知识,其中主要介绍了添加唯一约束的问题,唯一性约束指表中一个字段或者多个字段联合起来可以唯一标识一条记录的约束,下面一起来看一下,希望对大家有帮助。教程:《Oracle教程》...
  • MySQL索引给拿捏住了
    1579阅读
    本篇文章给大家带来了关于mysql的知识,其中主要介绍了关于mysql索引的问题,包括了索引按照逻辑功能划分、按照物理实现划分、按照字段个数划分等索引类型问题,希望对大家有帮助。学习:mysql教程在 SQL 优化中,索...
  • oracle怎么删除trigger
    1526阅读
    在oracle中,可以利用DROP TRIGGER语句来删除trigger,DROP语句用于进行删除操作,DROP TRIGGER语句的作用就是删除指定的trigger,语法为“DROP TRIGGER 需要删除的trigger名称;”。本教程操作环境:Windows10系统、...
  • oracle怎么将时间日期转换成时间戳
    1523阅读
    转换方法:1、使用to_char()函数,可将时间日期按照指定的格式输出,得到的是字符串,语法“to_char(日期,"转换格式")”;2、使用to_date()函数,语法“to_date("时间字符串","转换的时间日期格式")”。本教程操作环...

如本文对您有帮助,随意赞赏一下!