溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JAVA中需要謹(jǐn)慎使用Date和Time類(lèi)

發(fā)布時(shí)間:2021-11-30 17:00:36 來(lái)源:億速云 閱讀:252 作者:小新 欄目:編程語(yǔ)言

這篇文章將為大家詳細(xì)講解有關(guān)JAVA中需要謹(jǐn)慎使用Date和Time類(lèi),小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

AVA里提供的日期和時(shí)間類(lèi),java.sql.Date和java.sql.Time,只會(huì)從數(shù)據(jù)庫(kù)里讀取某部分值,這有時(shí)會(huì)導(dǎo)致丟失數(shù)據(jù)。例如一個(gè)包含2002/05/22 5:00:57 PM的字段,讀取日期時(shí)得到的是2002/05/22,而讀取時(shí)間時(shí)得到的是5:00:57 PM.


你需要了解數(shù)據(jù)庫(kù)里存儲(chǔ)時(shí)間的精度。有些數(shù)據(jù)庫(kù),比如MySQL,精度為毫秒,然而另一些數(shù)據(jù)庫(kù),包括Oracle,存儲(chǔ)SQL DATE類(lèi)型數(shù)據(jù)時(shí),毫秒部分的數(shù)據(jù)是不保存的。以下操作中容易出現(xiàn)不易被發(fā)現(xiàn)的BUG:

獲得一個(gè)JAVA里的日期對(duì)象。
從數(shù)據(jù)庫(kù)里讀取日期
試圖比較兩個(gè)日期對(duì)象是否相等。如果毫秒部分丟失,本來(lái)認(rèn)為相等的兩個(gè)日期對(duì)象用Equals方法可能返回false。
java.sql.Timestamp類(lèi)比java.util.Date類(lèi)精確度要高。這個(gè)類(lèi)包含了一個(gè)getTime()方法,但是它不會(huì)返回額外精度部分的數(shù)據(jù),因此必須使用getNanos()方法。有毫微秒部分(即額外精度部分)的數(shù)值可能比沒(méi)有這個(gè)部分的數(shù)值的大一個(gè)毫秒。如果你知道你使用的數(shù)據(jù)庫(kù)保存了毫秒部分,可以用下面的代碼獲得的數(shù)值:

long time=timestamp.getTime()+timestamp.getNanos()/1000000;
毫微秒的部分就是為什么一個(gè)java.sql.Timestamp對(duì)象不等于一個(gè)java.util.Date對(duì)象,而一個(gè)java.util.Date對(duì)象可能等于一個(gè)java.sql.Timestamp對(duì)象的原因。這使得equals方法應(yīng)當(dāng)保持的對(duì)稱(chēng)被打破了。

使用java.sql包中的時(shí)間相關(guān)的類(lèi)是重要的,但是它們也可能導(dǎo)致人為的錯(cuò)誤。

這是因?yàn)?,這些類(lèi)的復(fù)雜性雖然已經(jīng)在javadoc里面清楚的描述了,但是由于這些類(lèi)看上去很簡(jiǎn)單而很少有人看這些文檔。

關(guān)于“JAVA中需要謹(jǐn)慎使用Date和Time類(lèi)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI