【笔记】判断输入值是否为数字(函数)

本文介绍了在Oracle数据库中使用三种不同方法来判断一个字符串是否可以转换为有效数字的具体实现过程。包括使用TO_NUMBER进行类型转换、利用正则表达式进行模式匹配以及借助TRANSLATE函数移除非数字字符的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--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;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22786751/viewspace-621878/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/22786751/viewspace-621878/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值