SQL> CREATE OR REPLACE FUNCTION is_number (parmin VARCHAR2)
2 RETURN NUMBER
3 IS
4 val NUMBER;
5 BEGIN
6 val := TO_NUMBER (NVL (parmin, 'a'));
7 RETURN 1;
8 EXCEPTION
9 WHEN OTHERS
10 THEN
11 RETURN 0;
12 END;
13 /
RETURN NUMBER
IS
val DATE;
BEGIN
val := TO_DATE (NVL (parmin, 'a'), 'yyyy-mm-dd hh24:mi:ss');
RETURN 1;
EXCEPTION
WHEN OTHERS
THEN
RETURN 0;
END;
/
--------------------
1
2 RETURN NUMBER
3 IS
4 val NUMBER;
5 BEGIN
6 val := TO_NUMBER (NVL (parmin, 'a'));
7 RETURN 1;
8 EXCEPTION
9 WHEN OTHERS
10 THEN
11 RETURN 0;
12 END;
13 /
Function created.
SQL> select is_number('a') from dual;
IS_NUMBER('A')
--------------
0
--------------
0
SQL> select is_number('0.998') from dual;
IS_NUMBER('0.998')
------------------
1
------------------
1
SQL> select is_number('9999999999999999') from dual;
IS_NUMBER('9999999999999999')
-----------------------------
1
-----------------------------
1
由于session的语言设置会影响日期的输出格式,所以时间被转换为字符可能有多种形式。
以下这个函数只能满足部分情况,仅供参考
CREATE OR REPLACE FUNCTION is_date (parmin VARCHAR2)
以下这个函数只能满足部分情况,仅供参考
RETURN NUMBER
IS
val DATE;
BEGIN
val := TO_DATE (NVL (parmin, 'a'), 'yyyy-mm-dd hh24:mi:ss');
RETURN 1;
EXCEPTION
WHEN OTHERS
THEN
RETURN 0;
END;
/
Function created.
SQL> select is_date('a') from dual;
IS_DATE('A')
------------
0
------------
0
SQL> select is_date('2004-05-05') from dual;
IS_DATE('2004-05-05')
---------------------
1
---------------------
1
SQL> select is_date('2004/01/01') from dual;
IS_DATE('2004/01/01')
---------------------
1
---------------------
1
SQL> select is_date('01/01/04') from dual;
IS_DATE('01/01/04')
-------------------
1
-------------------
1
SQL> select is_date('01-jan-04') from dual;
IS_DATE('01-JAN-04')
--------------------
1
转载于:https://blog.51cto.com/zhaizhenxing/134782