SELECT TO_NUMBER('*') FROM DUAL
这显然给了我一个异常ORA-01722:无效的数字。
有没有办法“跳过”它,并获得0或NULL?
整个问题:我有NVARCHAR2字段,其中包含数字,而不是几乎; – )(像*),我需要从列中选择最大的数字。
是的,我知道这是一个可怕的设计,但这是我现在需要…:-S
UPD:
对于我自己,我已经解决了这个问题
COALESCE(TO_NUMBER(REGEXP_SUBSTR(field,'^\d+')),0)
我找不到比这更好的东西:
原文链接:https://www.f2er.com/oracle/206925.htmlfunction safe_to_number(p varchar2) return number is v number; begin v := to_number(p); return v; exception when others then return 0; end;