首页 > 数据库技术 > 详细

ORACLE 判断是否为数字类型

时间:2019-12-24 16:17:20      阅读:133      评论:0      收藏:0      [点我收藏+]

接到一个需求要判断一个varchar2字段的值是否是数字,如果不是数字,就置为null,如果是数字,就使用to_number把它变成num类型。

找到两种办法。

方法一:

用trim和translate来判断,这种方法比较麻烦,代码如下:

SELECT
    TO_NUMBER(t.ITM_VAL) test
    ,t.ITM_VAL
from EMR.T_REC t where trim(translate(t.ITM_VAL,‘0123456789.‘,‘ ‘)) is NOT NULL

方法二:

使用替换方法,把非数字和小数点的字符变为空,然后使用to_number,代码如下:

SELECT
    TO_NUMBER(REGEXP_REPLACE(t.ITM_VAL,‘[^0-9.]‘,‘‘)) test
    ,t.ITM_VAL
from EMR.T_REC t

 

ORACLE 判断是否为数字类型

原文:https://www.cnblogs.com/cykfory/p/12091521.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!