主页 > 知识库 > Oracle中判断字段是否为数字

Oracle中判断字段是否为数字

热门标签:爱客外呼系统怎么样 地图标注养老院 哈尔滨电话机器人销售招聘 哪个400外呼系统好 百度地图标注途经点 慧营销crm外呼系统丹丹 图吧网站地图标注 山东crm外呼系统软件 开发外呼系统

  在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道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使用sql语句增加字段示例(sql删除字段语句)
  • Oracle 插入超4000字节的CLOB字段的处理方法
  • oracle关键字作为字段名使用方法
  • 深入浅析mybatis oracle BLOB类型字段保存与读取
  • 简单三步轻松实现ORACLE字段自增
  • oracle数据库中如何处理clob字段方法介绍
  • Oracle 查询表信息获取表字段及字段注释
  • java读写oracle的blob字段示例
  • ORACLE中段的HEADER_BLOCK示例详析

标签:固原 和田 周口 甘肃 承德 开封 武汉 青岛

巨人网络通讯声明:本文标题《Oracle中判断字段是否为数字》,本文关键词  Oracle,中,判断,字段,是否,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Oracle中判断字段是否为数字》相关的同类信息!
  • 本页收集关于Oracle中判断字段是否为数字的相关信息资讯供网民参考!
  • 推荐文章