首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Oracle中的有效日期检查

Oracle中的有效日期检查
EN

Stack Overflow用户
提问于 2013-02-05 15:15:57
回答 5查看 71.1K关注 0票数 5

我以varchar格式存储了一个日期值(有效日期或无效日期)。是否可以在sql查询中检查日期是否有效。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2013-02-05 15:24:12

是的,如果你知道它的格式,并且用了一点plsql。

假设您有'yyyy-mon-dd hh24:mi:ss'格式的日期。

代码语言:javascript
运行
复制
create function test_date(d varchar2) return varchar2
is
  v_date date;
begin
  select to_date(d,'yyyy-mon-dd hh24:mi:ss') into v_date from dual;
  return 'Valid';
  exception when others then return 'Invalid';
end;

现在,您可以:

代码语言:javascript
运行
复制
select your_date_col, test_date(your_date_col)
from your_table;
票数 10
EN

Stack Overflow用户

发布于 2013-02-05 15:25:28

你可以像这样在一个块中完成它

代码语言:javascript
运行
复制
BEGIN
  select TO_DATE(your_date,'YYYYMMDD') from dual; --ADD INTO V_DUMMY IN PLSQL
EXCEPTION WHEN OTHERS THEN dbms_output.put_line('NOT A VALID DATE');
END;
票数 4
EN

Stack Overflow用户

发布于 2013-02-05 20:01:06

只需使用to_date函数检查日期是否有效/无效即可。

代码语言:javascript
运行
复制
BEGIN
  select TO_DATE(your_date,DateFormat) from dual;
EXCEPTION WHEN OTHERS THEN dbms_output.put_line('NOT A VALID DATE');
END;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14702050

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档