Oracle中isnumeric的三种实现
来源:优易学  2011-9-3 17:15:38   【优易学:中国教育考试门户网】   资料下载   IT书店
  许多用过ASP的朋友对isnumeric函数都有一定的了解,这是一个常用的判断入参是否为数字的函数。而在Oracle中没有现成的判断是否为数字函数,下面我们就来介绍一下如何用三种方法来将其实现:
  1. 利用 to_number
  CREATE OR REPLACE FUNCTION isnumeric (str IN VARCHAR2)
  RETURN NUMBER
  IS
  v_str FLOAT;
  BEGIN
  IF str IS NULL
  THEN
  RETURN 0;
  ELSE
  BEGIN
  SELECT TO_NUMBER (str)
  INTO v_str
  FROM DUAL;
  EXCEPTION
  WHEN INVALID_NUMBER
  THEN
  RETURN 0;
  END;
  RETURN 1;
  END IF;
  END isnumeric;
  2. 利用 regexp_like
  CREATE OR REPLACE FUNCTION isnumeric (str IN VARCHAR2)
  RETURN NUMBER
  IS
  BEGIN
  IF str IS NULL
  THEN
  RETURN 0;
  ELSE
  IF regexp_like (str, '^(-{0,1}+{0,1})[0-9]+(.{0,1}[0-9]+)$')
  THEN
  RETURN 1;
  ELSE
  RETURN 0;
  END IF;
  END IF;
  END isnumeric;
  3. 利用 TRANSLATE
  CREATE OR REPLACE FUNCTION isnumeric (str IN VARCHAR2)
  RETURN NUMBER
  IS
  v_str VARCHAR2 (1000);
  BEGIN
  IF str IS NULL
  THEN
  RETURN 0;
  ELSE
  v_str := TRANSLATE (str, '.0123456789', '.');
  IF v_str = '.' OR v_str = '+.' OR v_str = '-.' OR v_str IS NULL
  THEN
  RETURN 1;
  ELSE
  RETURN 0;
  END IF;
  END IF;
  END isnumeric;

责任编辑:小草

文章搜索:
 相关文章
热点资讯
热门课程培训