您好,登錄后才能下訂單哦!
使用mybatis注入Date日期時(shí)出現(xiàn)值為null怎么解決?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
在今天的一次代碼編寫(xiě)中,突然遇到了一個(gè)奇怪的問(wèn)題,在使用mybatis進(jìn)行Date類(lèi)型插入時(shí),可以很順利的就插入進(jìn)數(shù)據(jù)庫(kù)中了,可是當(dāng)我想從mysql中取出Date類(lèi)型的值注入java中的Date類(lèi)型時(shí),發(fā)現(xiàn)傳遞過(guò)來(lái)的值是空的,但是不管是映射還是命名規(guī)范都是正確的,就非常的奇怪。
數(shù)據(jù)庫(kù)設(shè)計(jì):
映射類(lèi)的設(shè)計(jì):
@Data public class BorrowTime { //借書(shū)時(shí)間 private Date borrowTime; //過(guò)期時(shí)間 private Date expiredTime; }
mapper類(lèi):
@Select("SELECT borrow_time,expired_time FROM book_user WHERE bid IN (SELECT bid FROM book_user WHERE uid =#{uid})") public List<BorrowTime> findBorrowTime(Integer uid);
查詢出來(lái)的值卻是這樣的:
在網(wǎng)上搜索了很多的資料,試了很多種方法都沒(méi)有效果,突然想到mybatis在進(jìn)行查詢的時(shí)候可以自動(dòng)的配置對(duì)應(yīng)的映射property,于是便去mapper中試了一下:
@Select("SELECT borrow_time,expired_time FROM book_user WHERE bid IN (SELECT bid FROM book_user WHERE uid =#{uid})") @Results({ @Result(column = "borrow_time",property = "borrowTime"), @Result(column = "expired_time",property = "expiredTime") }) public List<BorrowTime> findBorrowTime(Integer uid);
手動(dòng)的去將每一個(gè)columns和Property對(duì)應(yīng),然后再去查詢
終于出現(xiàn)了想要的結(jié)果,所以可能是映射字段的問(wèn)題還是其他的問(wèn)題還有待以后查證。
關(guān)于使用mybatis注入Date日期時(shí)出現(xiàn)值為null怎么解決問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(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)容。