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;