BigDecimal類型數(shù)據(jù)長(zhǎng)度過(guò)長(zhǎng)導(dǎo)致程序報(bào)出從數(shù)據(jù)類型 nvarchar 轉(zhuǎn)換為 decimal 時(shí)出錯(cuò)。

Error updating database. Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 從數(shù)據(jù)類型 nvarchar 轉(zhuǎn)換為 decimal 時(shí)出錯(cuò)。

????第一眼看到這個(gè)錯(cuò)誤的時(shí)候,馬上就去看了一下值類型發(fā)現(xiàn)沒有問(wèn)題,接著調(diào)試,結(jié)果還是報(bào)出這個(gè)錯(cuò)誤,納悶之余,我把這個(gè)BigDecimal類型

的值用.getclass然后輸出出來(lái),看下到底這個(gè)值是什么類型,結(jié)果打印出來(lái)是class java.math.BigDecimal類型。不過(guò)這個(gè)條數(shù)據(jù)小數(shù)點(diǎn)后足足有59

位,因?yàn)檫@個(gè)值是從Double類型的值強(qiáng)轉(zhuǎn)過(guò)來(lái)的。于是乎我把該值用.setScale(2, BigDecimal.ROUND_FLOOR);保留兩位小數(shù),最后調(diào)試程序,就

不報(bào)錯(cuò)了,很基礎(chǔ)的一個(gè)問(wèn)題,但是以前沒遇到過(guò),所以分享出來(lái)這個(gè)小小坑。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容