Oracle日期显示问题以及trunc方法的使用

WBOY
リリース: 2016-06-07 17:40:18
オリジナル
892 人が閲覧しました

我们先来假设这么一个场景,只要输入一个到月份的日期进入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徐胖子的专栏” 博客,请务必保留此出处

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!