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。当然这只是显示问题,操作时只要截取你需要的即可。

本文转自IT徐胖子的专栏博客51CTO博客,原文链接http://blog.51cto.com/woshixy/956458如需转载请自行联系原作者


woshixuye111

相关文章
|
4月前
|
SQL Oracle 关系型数据库
Oracle之日期计算相关函数
Oracle之日期计算相关函数
45 0
|
5月前
|
Oracle 关系型数据库
Oracle新建数据表的两种方法
Oracle新建数据表的两种方法
|
4月前
|
SQL Oracle 关系型数据库
Oracle之替代OR的另一种方法
Oracle之替代OR的另一种方法
75 0
|
4月前
|
SQL Oracle 关系型数据库
oracle中日期循环
oracle中日期循环
59 0
|
9月前
|
SQL 存储 Oracle
Oracle数据库中日期的操作、主键自增与分页查询
Oracle数据库中日期的操作、主键自增与分页查询
79 0
|
7月前
|
存储 Oracle Java
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
|
7月前
|
SQL Oracle 关系型数据库
Oracle数据库优化的总结及优化方法
Oracle数据库优化的总结及优化方法
56 0
|
8月前
|
Oracle 关系型数据库 数据库
Oracle 数据库中常见的日期和时间函数
Oracle 数据库中常见的日期和时间函数
142 0
|
8月前
|
Oracle 关系型数据库
Oracle日期加减运算实战演练
Oracle日期加减运算实战演练
60 0
|
10月前
|
SQL Oracle 关系型数据库
一种SqlServer数据迁移到Oracle的方法总结
一种SqlServer数据迁移到Oracle的方法总结
370 0