前端之家收集整理的这篇文章主要介绍了
oracle – “安全”TO_NUMBER(),
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
SELECT TO_NUMBER('*') FROM DUAL
这显然给了我一个异常ORA-01722:无效的数字。
有没有办法“跳过”它,并获得0或NULL?
整个问题:我有NVARCHAR2字段,其中包含数字,而不是几乎; – )(像*),我需要从列中选择最大的数字。
是的,我知道这是一个可怕的设计,但这是我现在需要…:-S
UPD:
对于我自己,我已经解决了这个问题
COALESCE(TO_NUMBER(REGEXP_SUBSTR(field,'^\d+')),0)
@H_
301_17@
@H_
301_17@
我找不到比这更好的东西:
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;
@H_
301_17@
原文链接:https://www.f2er.com/oracle/206925.html