当前位置导航:炫浪网>>网络学院>>编程开发>>Oracle教程

详细讲解Oracle中isnumeric的三种实现

  许多用过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;

相关内容
赞助商链接