微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何测试日期格式字符串是否为Oracle中的有效日期格式字符串

我希望用户能够输入日期格式字符串,以便他们可以指定他们希望如何显示/输入日期值.

如何验证此日期格式字符串,以便它们只能输入有效的Oracle日期格式字符串?

解决方法

你可以创建一个函数

例如:

FUNCTION is_valid_date_format ( 
    p_format IN VARCHAR2 ) 
RETURN BOOLEAN IS
    l_date VARCHAR2(100) := NULL;
BEGIN
    l_date := TO_char( sysdate,p_format );
    RETURN TRUE;
EXCEPTION
    WHEN OTHERS THEN
        RETURN FALSE;
END is_valid_date_format;

并像这样使用它

IF is_valid_date_format('dd/mm/yyyy') THEN

目前它也将允许时间格式,但是将它扩展为不允许包含不需要的格式的格式会很简单,例如:hh hh24 mi ss

通过添加:(您可能希望首先大写您的格式字符串)

IF INSTR(p_format,'HH')>0 OR INSTR(p_format,'HH24')>0 
OR INSTR(p_format,'MI')>0  OR INSTR(p_format,'SS')>0 THEN
    RETURN FALSE
END IF;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐