您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關JAVA中需要謹慎使用Date和Time類,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
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里面清楚的描述了,但是由于這些類看上去很簡單而很少有人看這些文檔。
關于“JAVA中需要謹慎使用Date和Time類”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。