如何判断一个字符串是否为数字或日期?
如何判断一个字符串是否为数字?我说,写一个函数吧。于是给出了一个例子:SQL> CREATE OR REPLACE FUNCTION is_number (parmin VARCHAR2)2 RETURN NUMBER3 IS4 val NUMBER;5 BEGIN6 val := TO_NUMBER (NVL (parmin, 'a'));7 RETURN 1;8 EXCEPTION9 WHEN OTHERS10 THEN11 RETURN 0;12 END;13 / Function created。 SQL> select is_number('a') from dual;IS_N...全部
如何判断一个字符串是否为数字?我说,写一个函数吧。于是给出了一个例子:SQL> CREATE OR REPLACE FUNCTION is_number (parmin VARCHAR2)2 RETURN NUMBER3 IS4 val NUMBER;5 BEGIN6 val := TO_NUMBER (NVL (parmin, 'a'));7 RETURN 1;8 EXCEPTION9 WHEN OTHERS10 THEN11 RETURN 0;12 END;13 / Function created。
SQL> select is_number('a') from dual;IS_NUMBER('A')--------------0SQL> select is_number('0。998') from dual;IS_NUMBER('0。
998')------------------1SQL> select is_number('9999999999999999') from dual;IS_NUMBER('9999999999999999')-----------------------------1今天,这个朋友在MSN上又问:如何判断一个字符是否是日期?我说,再写一个函数吧。
补注:由于session的语言设置会影响日期的输出格式,所以时间被转换为字符可能有多种形式。以下这个函数只能满足部分情况,仅供参考。SQL> CREATE OR REPLACE FUNCTION is_date (parmin VARCHAR2)2 RETURN NUMBER3 IS4 val DATE;5 BEGIN6 val := TO_DATE (NVL (parmin, 'a'), 'yyyy-mm-dd hh24:mi:ss');7 RETURN 1;8 EXCEPTION9 WHEN OTHERS10 THEN11 RETURN 0;12 END;13 /Function created。
SQL> select is_date('a') from dual;IS_DATE('A')------------0SQL> select is_date('2004-05-05') from dual;IS_DATE('2004-05-05')---------------------1SQL> select is_date('2004/01/01') from dual;IS_DATE('2004/01/01')---------------------1SQL> select is_date('01/01/04') from dual;IS_DATE('01/01/04')-------------------1SQL> select is_date('01-jan-04') from dual;IS_DATE('01-JAN-04')--------------------1这两者是何其相似啊!。
收起