如何判断一个字符串是否为数字或日期?
昨天有一个朋友在MSN上问,如何判断一个字符串是否为数字?
我说,写一个函数吧。于是给出了一个例子:
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 /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 NUMBER
3 IS
4 val DATE;
5 BEGIN
6 val := TO_DATE (NVL (parmin, 'a'), 'yyyy-mm-dd hh24:mi:ss');
7 RETURN 1;
8 EXCEPTION
9 WHEN OTHERS
10 THEN
11 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
这两者是何其相似啊!
-The End-
http://www.eygle.com/archives/2007/02/is_date_or_number.html
- ORACLE UPDATE 语句语法与
- 总结归纳:110个Oracle 常
- 新手必读:Oracle数据库操
- ORACLE数据库的基本语法集
- 如何在MySQL&Oracle下创建
- oracle 存储过程的基本语
- Oracle的hints调整机制介
- 关于oracle存储过程的若干
- Oracle 9i LogMiner工具使
- 如何判断一个字符串是否为
- 搭建Oracle高可用数据库环
- 网友经验:学习oracle快速
- 详细讲解Oracle数据库的结
- Oracle中的一些相关指令的
- 详细讲述 Oracle 密码丢失
- Oracle数据库中备份、恢复
- Oracle后台进程的功能简单
- Oracle 动态SQL返回单条结
- SQL Server 临时表 与 Ora
- Oracle 排序中常用的NULL

