Oracle日期显示问题以及trunc方法的使用

Linux大全评论808 views阅读模式

我们先来假设这么一个场景,只要输入一个到月份的日期进入Oracle,比如2012年8月。但是输入进了Oracle,会发现oracle自动补了个1号变成了2012-8-1,这并不是我们的本意。不要担心,这只是oracle的显示问题。当然我们需要在取出的时候进行处理。

比如需要找到2012年8月份的数据,我们假设该表的日期字段为mydate字段。

错误做法

where mydate =  to_char('2012.8','yyyy.mm')

这样只可以找出8.1号的数据

正确做法

and trunc(mydate,'mm')  =  to_date('2012.8,'yyyy.mm') 将该字段阶段至月份,只比较到月份

当然trunc也有显示的问题,现在是2012.8.6

select trunc(sysdate,'mm') from dual;

结果 2012-8-1

自动补上了一个1

 

select trunc(sysdate,'yy) from dual;

结果 2012-1-1

企鹅博客
  • 本文由 发表于 2020年9月8日 23:28:02
  • 转载请务必保留本文链接:https://www.qieseo.com/185743.html

发表评论