欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis相同的sql查詢第二次查不出結(jié)果問題

 更新時間:2022年01月21日 15:22:58   作者:暗香撫動  
這篇文章主要介紹了mybatis相同的sql查詢第二次查不出結(jié)果問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

相同的sql查詢第二次查不出結(jié)果問題

問題分析

今天在做公司業(yè)務(wù),大致是用戶傳來訂單號(買卡)和手機號對其進行卡綁定,其中如果已經(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緩存介紹

一級緩存:即session緩存,作用域為 Session,當 Session flush 或 close 之后,該Session中的所有 Cache 就將清空,默認開啟。注意:集成spring(使用mybatis-spring)時:

每次查詢spring會重新創(chuàng)建SqlSession,所以一級緩存是不生效的;

而當開啟事務(wù)時,spring會使用同一個SqlSession做查詢,所以這個情況下一級緩存是生效的。

二級緩存:即全局緩存,其作用域為 Mapper(Namespace),默認關(guān)閉。

問題原因

上述提到了MyBatis的緩存機制,查看項目配置后發(fā)現(xiàn)問題在于第一次查詢到結(jié)果會放到緩存中,程序?qū)Σ榈降慕Y(jié)果list進行了remove操作,所以緩存中的list會發(fā)生變化,第二次查詢時會從緩存中將操作過的list查找出來(mybatis返回的實體類的內(nèi)存地址是相同的),故而產(chǎn)生了我們不需要的結(jié)果,之前項目中使用的是與Spring集成的,使用的session是SqlSessionTemplate,這里是默認關(guān)閉了一級緩存,而今天項目中沒有與Spring集成,創(chuàng)建session使用的是SqlsessionFactory的openSession()方法,這里查找時默認會先從緩存中查詢,綜上,第二次我們查到的只是緩存中的數(shù)據(jù)[2]。

解決方案

既然第二次會從緩存中讀數(shù)據(jù),不可能修改項目配置關(guān)閉一級緩存,所以可以通過刷新緩存來達到我們所需要的目的

方案一:通過SqlSessionUtils.getSqlSession(sqlSessionFactory).clearCache()方法刷新緩存

方案二:在mapper.xml對應(yīng)的查找語句中添加flushCache="true"

<select id="selectCardInfoByOrderId" resultType="xxx" parameterType="java.util.Map" flushCache="true"></select>

mybatis條件查詢?nèi)菀子鲆姷腻e誤

在使用mybatis的條件查詢時,

一不小心就容易出現(xiàn)這個錯誤

19-Dec-2017 16:04:38.742 嚴重 [http-nio-8090-exec-6] org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [SpringMVC] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'] with root cause org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:380)at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:170)at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:152)at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:48)

這是mapper.xml文件:

<select id="findByEndoscopeType" resultMap="BaseResultMap" parameterType="java.lang.String">
? ? SELECT *
? ? FROM endoscope
? ? <where>
? ? ? ? <if test="endoscopeType != null">
? ? ? ? ? ? endoscope_type = #{endoscopeType,jdbcType=VARCHAR}
? ? ? ? </if>
? ? </where>
</select>

出錯的原因是因為加上 <if> 標簽時,endoscope屬性沒有包含在String endoscopeType中

兩種解決方法

1.將<if>標簽去掉;

2.傳入?yún)?shù)放在對象中傳進來;

<select id="findByEndoscopeType" resultMap="BaseResultMap" parameterType="com.iel.endoscope.entity.Endoscope">
? ? SELECT *
? ? FROM endoscope
? ? <where>
? ? ? ? <if test="endoscopeType != null">
? ? ? ? ? ? endoscope_type = #{endoscopeType,jdbcType=VARCHAR}
? ? ? ? </if>
? ? </where>
</select>

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java Metrics系統(tǒng)性能監(jiān)控工具的使用詳解

    Java Metrics系統(tǒng)性能監(jiān)控工具的使用詳解

    Metrics是一個Java庫,可以對系統(tǒng)進行監(jiān)控,統(tǒng)計一些系統(tǒng)的性能指標。本文就來和大家詳細聊聊這個工具的具體使用,希望對大家有所幫助
    2022-11-11
  • java高并發(fā)ScheduledThreadPoolExecutor與Timer區(qū)別

    java高并發(fā)ScheduledThreadPoolExecutor與Timer區(qū)別

    這篇文章主要為大家介紹了java高并發(fā)ScheduledThreadPoolExecutor與Timer區(qū)別,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • Geotools實現(xiàn)shape文件的寫入功能

    Geotools實現(xiàn)shape文件的寫入功能

    Geotools作為開源的Java?GIS三方庫,已經(jīng)成為GIS服務(wù)器端的主流開源庫,其功能非常強大,涉及到GIS業(yè)務(wù)的方方面面,其中就包括GIS數(shù)據(jù)的讀寫,今天小編就借助Geotools來實現(xiàn)shape數(shù)據(jù)的寫入,需要的朋友可以參考下
    2023-08-08
  • JAVA如何使用Math類操作數(shù)據(jù)

    JAVA如何使用Math類操作數(shù)據(jù)

    這篇文章主要介紹了JAVA如何使用Math類操作數(shù)據(jù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • 解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題

    解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題

    這篇文章主要介紹了解決springboot使用logback日志出現(xiàn)LOG_PATH_IS_UNDEFINED文件夾的問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • RabbitMQ消息隊列的目錄結(jié)構(gòu)

    RabbitMQ消息隊列的目錄結(jié)構(gòu)

    這篇文章主要介紹了RabbitMQ消息隊列的目錄結(jié)構(gòu),RabbitMQ?屬于消息中間件,主要用于組件之間的解耦,消息的發(fā)送者無需知道消息使用者的存在,反之亦然,那么用了那么久RabbitMQ,其目錄結(jié)構(gòu)是怎樣的呢,讓我們一起來看一下吧
    2023-08-08
  • Java實現(xiàn)數(shù)獨小游戲

    Java實現(xiàn)數(shù)獨小游戲

    這篇文章主要為大家詳細介紹了Java實現(xiàn)數(shù)獨小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Java里的static import使用小結(jié)

    Java里的static import使用小結(jié)

    這篇文章主要介紹了Java里的static import使用小結(jié),本文給出了一些使用示例,并總結(jié)了一些使用特性,需要的朋友可以參考下
    2015-06-06
  • Java JVM虛擬機運行機制

    Java JVM虛擬機運行機制

    JVM(Java虛擬機)一種用于計算設(shè)備的規(guī)范,可用不同的方式(軟件或硬件)加以實現(xiàn)。接下來通過本文給大家簡單介紹Java JVM虛擬機運行機制,感興趣的朋友一起看看吧
    2017-03-03
  • 解決json串和實體類字段不一致的問題

    解決json串和實體類字段不一致的問題

    這篇文章主要介紹了解決json串和實體類字段不一致的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03

最新評論