Oracle日期显示问题以及trunc方法的使用
程序员文章站
2022-06-02 18:37:12
...
我们先来假设这么一个场景,只要输入一个到月份的日期进入Oracle,比如2012年8月。但是输入进了Oracle,会发现oracle自动补了个1号变成了2012-8-1,这并不是我们
我们先来假设这么一个场景,只要输入一个到月份的日期进入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徐胖子的专栏” 博客,请务必保留此出处
推荐阅读
-
解决layui的使用以及针对select、radio等表单组件不显示的问题
-
使用php+apc实现上传进度条且在IE7下不显示的问题解决方法
-
Oracle插入日期数据常见的2个问题和解决方法
-
解决layui的使用以及针对select、radio等表单组件不显示的问题
-
php使用cookie显示用户上次访问网站日期的方法
-
framework7的改进,以及与vue组合使用遇到的问题以及解决方法 (附vue的原理)
-
Python使用matplotlib绘图无法显示中文问题的解决方法
-
Oracle中定义以及使用同义词的方法
-
使用php+apc实现上传进度条且在IE7下不显示的问题解决方法
-
电脑显示器经常出的问题以及日常保养方法的介绍