Oracle日期显示问题以及trunc方法的使用
我们先来假设这么一个场景,只要输入一个到月份的日期进入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
更过分,自动补上了两个1
Oracle就是这样,喜欢帮你补1。当然这只是显示的问题,操作的时候只要截取你需要的即可。
最后更新:2017-04-03 05:40:22
上一篇:
iBATIS批量操作
下一篇:
Mybatis传递多个参数
如何防止数据被盗 把黑客拒之门外
android 布局方式说明.
2013年全球重要黑客大会一览
人工智能概念第一股?即将在美国上市的Veritone是怎样一家公司
J2EE中自定义标签以及TagSupport和BodyTagSupport的用法
Google Play开发者账号注册教程(new)
HTAP数据库 PostgreSQL 场景与性能测试之 36 - (OLTP+OLAP) 不含索引单表批量写入
专家:建设智慧城市 需要各方协同共享数据
[综合面试] 牛人整理分享的面试知识:操作系统、计算机网络、设计模式、Linux编程,数据结构总结
HDU 4741 空间几何求两直线距离最近点