Oracle日期显示问题以及trunc方法的使用 推荐
2012-08-06 22:00
495 查看
我们先来假设这么一个场景,只要输入一个到月份的日期进入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。当然这只是显示问题,操作时只要截取你需要的即可。
比如需要找到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。当然这只是显示问题,操作时只要截取你需要的即可。
相关文章推荐
- Oracle日期显示问题以及trunc方法的使用
- ASP.NET中TextBox使用Ajax控件显示日期不全的问题解决方法
- Android问题—Toast不显示的原因和在子线程中使用方法以及Looper类详细解析
- ASP.NET中TextBox使用Ajax控件显示日期不全的问题解决方法
- 取从textarea中存到MYSQL的数据以原格式显示问题以及解决MySQL日期处理和标签的使用
- Genymotion配置和使用教程以及常见问题解决方法
- 在Ubuntu中使用Python的matplotlib库时图片不能显示问题的解决方法
- Logstash使用遇到问题以及解决方法
- 解决pandas无法在pycharm中使用plot()方法显示图像的问题
- 使用DatePicker以及TimePicker显示当前日期和时间
- python3中使用builtwith以及各种疑难问题的方法
- Android 使用DatePicker以及TimePicker显示当前日期和时间
- oracle 11g安装过程中的所有问题以及解决方法
- Android Studio-—使用OpenCV的配置方法和demo以及开发过程中遇到的问题解决
- 缓存需要注意的问题以及使用.net正则替换字符串的方法
- windows下安装python basemap时使用Visual Studio编译geos时遇到的问题以及解决方法
- oracle ilearning中文汉字问题解决办法以及HTTP调试工具Fiddler的使用方法介绍
- 不装oracle客户端使用plsql,以及中文乱码问号问题(也可以解决VC调用oracle 乱码问题)
- Ubuntu 配置VNC以及使用VNC连接时,无法显示系统菜单栏,解决方法