Java调优:Mybaitis的缓存优化
作者:肥朝,來(lái)自肥朝(ID:feichao_java)
我們先來(lái)看代碼
這段代碼中, Mybatis一共發(fā)了兩條SQL,這就好像說(shuō), Mybatis中沒(méi)有緩存,然后我們打開(kāi)Mybatis的文檔一看,頓時(shí)震驚
這難道是騙人的,說(shuō)好的默認(rèn)開(kāi)啟緩存呢…..
其實(shí)不是的,默認(rèn)確實(shí)是開(kāi)啟緩存的,但是我們還需要配置一點(diǎn)東西
UserMapper.xml
另外,對(duì)象還要實(shí)現(xiàn)序列化接口,否則報(bào)NotSerializableException的異常
設(shè)置完畢之后,我們?cè)賮?lái)嘗試insert的問(wèn)題
此時(shí)發(fā)現(xiàn),發(fā)了3條SQL,那么究竟是什么原因呢?如下圖
看完這個(gè)圖,就明白為什么get(1L)->add()->get(1L)這個(gè)過(guò)程會(huì)發(fā)3條SQL了,因?yàn)閕nsert的時(shí)候,清空了緩存
但是就算insert,并沒(méi)有影響到get(1L)的結(jié)果,但是你卻把他的緩存也清空了,這明顯不合理,那么我們?cè)趺磧?yōu)化呢?
那么我們可不可以這樣做呢?如圖:
也就是我們做了兩件事
list由于緩存命中率低,那么我們就不加入到緩存中
insert我們不清空緩存
那么在代碼中,我們具體是怎么實(shí)現(xiàn)的呢?
UserMapper.xml
這樣之后,我們Mybatis中的緩存就更高效了
【End】
老王給大家準(zhǔn)備一份「Java最常見(jiàn)200+面試題全解析」,助力大家找到更好的工作,這份面試題包含的模塊:
Java、JVM?最常見(jiàn)面試題解析
Spring、Spring?MVC、MyBatis、Hibernate?面試題解析
MySQL、Redis?面試題解析
RabbitMQ、Kafka、Zookeeper?面試解析
微服務(wù)?Spring?Boot、Spring?Cloud?面試解析
掃描下面二維碼付費(fèi)閱讀
關(guān)注下方二維碼,訂閱更多精彩內(nèi)容。
轉(zhuǎn)發(fā)朋友圈,是對(duì)我最大的支持。
總結(jié)
以上是生活随笔為你收集整理的Java调优:Mybaitis的缓存优化的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: MySQL 常见的开放性问题
- 下一篇: Java中常用的4个Json库,哪个性能