我们先来假设这么一个场景,只要输入一个到月份的日期进入Oracle,比如2012年8月。但是输入进了Oracle,会发现变成了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')
select trunc(sysdate,'mm') from dual;
结果 2012-8-1
自动补上了一个1
select trunc(sysdate,'yy) from dual;
结果 2012-1-1
更过分,自动补上了两个1
。当然这只是显示的问题,操作的时候只要截取你需要的即可。