-
問題分析:今天在做公司業(yè)務,大致是用戶傳來訂單號(買卡)和手機號對其進行卡綁定,其中如果已經(jīng)操作過則返回操作后的狀態(tài),問題出現(xiàn)在如果是項目啟動第一次訪問,會正常返回結(jié)果,第二次訪問時會報找不到卡信息的錯誤,但是代碼是同一個,查詢語句也一樣,為什么會出現(xiàn)這種情況?找遍百度,未果,自己摸索著尋找問題。
-
問題探索:首先對查詢方法進行了排除,未果;然后尋找代碼中問題,發(fā)現(xiàn)遍歷卡信息(可找到多張卡)時,對于已經(jīng)操作過的會進行remove()操作,注釋掉這行,程序有結(jié)果,但是會重新更新卡信息,不是需要的結(jié)果;最后發(fā)現(xiàn)是對list進行remove()操作時都會出錯,于是聯(lián)想到了MyBatis的緩存。
-
MyBatis緩存介紹[1]:
一級緩存:即session緩存,作用域為 Session,當 Session flush 或 close 之后,該Session中的所有 Cache 就將清空,默認開啟。注意:集成spring(使用mybatis-spring)時:
-
每次查詢spring會重新創(chuàng)建SqlSession,所以一級緩存是不生效的;
-
而當開啟事務時,spring會使用同一個SqlSession做查詢,所以這個情況下一級緩存是生效的。
二級緩存:即全局緩存,其作用域為 Mapper(Namespace),默認關閉。
-
-
問題原因:上述提到了MyBatis的緩存機制,查看項目配置后發(fā)現(xiàn)問題在于第一次查詢到結(jié)果會放到緩存中,程序?qū)Σ榈降慕Y(jié)果list進行了remove操作,所以緩存中的list會發(fā)生變化,第二次查詢時會從緩存中將操作過的list查找出來(mybatis返回的實體類的內(nèi)存地址是相同的),故而產(chǎn)生了我們不需要的結(jié)果,之前項目中使用的是與Spring集成的,使用的session是SqlSessionTemplate,這里是默認關閉了一級緩存,而今天項目中沒有與Spring集成,創(chuàng)建session使用的是SqlsessionFactory的openSession()方法,這里查找時默認會先從緩存中查詢,綜上,第二次我們查到的只是緩存中的數(shù)據(jù)[2]。
-
解決方案:既然第二次會從緩存中讀數(shù)據(jù),不可能修改項目配置關閉一級緩存,所以可以通過刷新緩存來達到我們所需要的目的
方案一:通過SqlSessionUtils.getSqlSession(sqlSessionFactory).clearCache()方法刷新緩存
方案二:在mapper.xml對應的查找語句中添加flushCache="true"
<select id="selectCardInfoByOrderId" resultType="xxx" parameterType="java.util.Map" flushCache="true"></select>
-
總結(jié):此次問題的發(fā)生與解決對MyBatis緩存進一步了解,至于提供的兩種方案有什么區(qū)別還需要繼續(xù)探索,并且接下來要對SqlSessionTemplate[3]和SqlSession[4]做更深層次的學習,最后感謝提供相關資料的各位博主!
MyBatis同一個查詢第一次能查到第二次查不到數(shù)據(jù)?
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
- 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
推薦閱讀更多精彩內(nèi)容
- 11 MyBatis一級緩存實現(xiàn)# 11.1 什么是一級緩存? 為什么使用一級緩存?## 每當我們使用MyBati...
- 前言 主題是Mybatis一級和二級緩存的應用及源碼分析。希望在本場chat結(jié)束后,能夠幫助讀者朋友明白以下三點。...
- Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn),斷路器,智...