JAVA基礎:謹慎使用Date和Time類(轉)
JAVA基礎:謹慎使用Date和Time類(轉)[@more@]AVA裡提供的日期和時間類,java.sql.Date和java.sql.Time,只會從資料庫裡讀取某部分值,這有時會導致丟失資料。例如一個包含2002/05/22 5:00:57 PM的欄位,讀取日期時得到的是2002/05/22,而讀取時間時得到的是5:00:57 PM.
你需要了解資料庫裡儲存時間的精度。有些資料庫,比如MySQL,精度為毫秒,然而另一些資料庫,包括Oracle,儲存SQL DATE型別資料時,毫秒部分的資料是不儲存的。以下操作中容易出現不易被發現的BUG:
獲得一個JAVA裡的日期物件。
從資料庫裡讀取日期
試圖比較兩個日期物件是否相等。如果毫秒部分丟失,本來認為相等的兩個日期物件用Equals方法可能返回false。
java.sql.Timestamp類比java.util.Date類精確度要高。這個類包含了一個getTime()方法,但是它不會返回額外精度部分的資料,因此必須使用getNanos()方法。有毫微秒部分(即額外精度部分)的數值可能比沒有這個部分的數值的大一個毫秒。如果你知道你使用的資料庫儲存了毫秒部分,可以用下面的程式碼獲得的數值:
long time=timestamp.getTime()+timestamp.getNanos()/1000000;
毫微秒的部分就是為什麼一個java.sql.Timestamp物件不等於一個java.util.Date物件,而一個java.util.Date物件可能等於一個java.sql.Timestamp物件的原因。這使得equals方法應當保持的對稱被打破了。
使用java.sql包中的時間相關的類是重要的,但是它們也可能導致人為的錯誤。
這是因為,這些類的複雜性雖然已經在javadoc裡面清楚的描述了,但是由於這些類看上去很簡單而很少有人看這些文件。
你需要了解資料庫裡儲存時間的精度。有些資料庫,比如MySQL,精度為毫秒,然而另一些資料庫,包括Oracle,儲存SQL DATE型別資料時,毫秒部分的資料是不儲存的。以下操作中容易出現不易被發現的BUG:
獲得一個JAVA裡的日期物件。
從資料庫裡讀取日期
試圖比較兩個日期物件是否相等。如果毫秒部分丟失,本來認為相等的兩個日期物件用Equals方法可能返回false。
java.sql.Timestamp類比java.util.Date類精確度要高。這個類包含了一個getTime()方法,但是它不會返回額外精度部分的資料,因此必須使用getNanos()方法。有毫微秒部分(即額外精度部分)的數值可能比沒有這個部分的數值的大一個毫秒。如果你知道你使用的資料庫儲存了毫秒部分,可以用下面的程式碼獲得的數值:
long time=timestamp.getTime()+timestamp.getNanos()/1000000;
毫微秒的部分就是為什麼一個java.sql.Timestamp物件不等於一個java.util.Date物件,而一個java.util.Date物件可能等於一個java.sql.Timestamp物件的原因。這使得equals方法應當保持的對稱被打破了。
使用java.sql包中的時間相關的類是重要的,但是它們也可能導致人為的錯誤。
這是因為,這些類的複雜性雖然已經在javadoc裡面清楚的描述了,但是由於這些類看上去很簡單而很少有人看這些文件。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617731/viewspace-961281/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- java流操作要謹慎Java
- 【Lambda、SteamAPI】謹慎使用流API
- 請謹慎使用sp_executesqlSQL
- java8中的LocalDate,LocalTime,LocalDateTime與Date的轉換和使用JavaLDA
- JavaSE基礎:System類和Runtime類Java
- UNIX下VG遷移(謹慎) - 轉
- Java 8 中新的 Date 和 Time 類入門詳解Java
- java 類基礎(轉)Java
- AIX系統謹慎使用reboot命令AIboot
- java:Date和DateTime區別Java
- C#:謹慎 DateTime.Now 帶來的危險C#
- Java:String和Date、Timestamp之間的轉換Java
- oracle中要謹慎使用update交叉更新!Oracle
- DBA要謹慎關閉資料庫(轉)資料庫
- js基礎–Date.parse()與Date.getTime()方法詳解JS
- Java基礎| 類和物件Java物件
- 【Java基礎】類和介面Java
- Linux需要謹慎使用的幾個命令Linux
- java convert timestamp to date and timeJava
- Java基礎Day07(Map Calender Date 包裝類 System類 異常)Java
- STL程式設計實踐一:謹慎使用下標運算子 (轉)程式設計
- Java學習--使用 Date 和 SimpleDateFormat 類表示時間JavaORM
- Java基礎-抽象類和介面Java抽象
- java Date日期類和SimpleDateFormat日期類格式JavaORM
- JAVA基礎:使用Properties類帶來的好處(轉)Java
- 為什麼要謹慎使用Linux find命令?Linux
- 大型專案開發:謹慎使用智慧指標指標
- 技術人,請謹慎跳槽!
- Java Date Time 教程-java.util.Calendar和GregorianCalendarJavaGo
- java -- Stringbuild、Date和Calendar類JavaUI
- java8 Date/Time APIJavaAPI
- JAVA裡的String、Timestamp、Date相互轉換Java
- Java基礎:類的深入研究(轉)Java
- 謹慎處理 Service Worker 的更新
- 升級oracle一定要謹慎Oracle
- AIX強制關機需要謹慎AI
- 謹慎做資料庫技術的標準化(轉)資料庫
- date和timestamp型別之間的轉換型別