oracle – “安全”TO_NUMBER()

前端之家收集整理的这篇文章主要介绍了oracle – “安全”TO_NUMBER()前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
SELECT TO_NUMBER('*') FROM DUAL
@H_502_3@这显然给了我一个异常ORA-01722:无效的数字。

@H_502_3@有没有办法“跳过”它,并获得0或NULL?

@H_502_3@整个问题:我有NVARCHAR2字段,其中包含数字,而不是几乎; – )(像*),我需要从列中选择最大的数字。

@H_502_3@是的,我知道这是一个可怕的设计,但这是我现在需要…:-S

@H_502_3@UPD:

@H_502_3@对于我自己,我已经解决了这个问题

COALESCE(TO_NUMBER(REGEXP_SUBSTR(field,'^\d+')),0)
我找不到比这更好的东西:
function safe_to_number(p varchar2) return number is
    v number;
  begin
    v := to_number(p);
    return v;
  exception when others then return 0;
end;

猜你在找的Oracle相关文章