`
tianshibaijia
  • 浏览: 1125380 次
文章分类
社区版块
存档分类
最新评论

Oracle中如何判断是否为数字函数

 
阅读更多

在Oracle中没有现成的判断是否为数字函数,下面我们就来介绍一下如何用三种方法来将其实现:

  1. 利用 to_number

  CREATE OR REPLACE FUNCTION is_numeric (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 is_numeric;

  2. 利用 regexp_like

  CREATE OR REPLACE FUNCTION is_numeric (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 is_numeric;

  3. 利用 TRANSLATE

  CREATE OR REPLACE FUNCTION is_numeric (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 is_numeric;

----整理自网上

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics