您好,登錄后才能下訂單哦!
這篇文章主要講解了“mybatis一直加載xml怎么解決”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“mybatis一直加載xml怎么解決”吧!
我們在寫springmvc+mybatis項目,啟動項目的時候,mapper配置文件一直刷,一直加載。。。。。
對于我們偉大的程序猿來說這并不可怕,可怕的是沒有錯誤打印出來。。。。。完全不知道如何下手啊,
找到org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory 類,在下面方法:
protected void autowireByType( String beanName, AbstractBeanDefinition mbd, BeanWrapper bw, MutablePropertyValues pvs) { catch (BeansException ex) { throw new UnsatisfiedDependencyException(mbd.getResourceDescription(), beanName, propertyName, ex); }
在throw這一行斷點即可,這個地方是最早捕獲異常的地方,當Mapper.xml文件出錯的時候,會有異常信息輸出。
還有一個問題,為什么出錯后只能看到無限輸出的一行日志,而看不到這里具體的異常信息呢?
通過追蹤代碼,發現在org.springframework.beans.factory.support.AbstractBeanFactory類中的方法:
protected Class<?> getTypeForFactoryBean(String beanName, RootBeanDefinition mbd) { if (!mbd.isSingleton()) { return null; } try { FactoryBean<?> factoryBean = doGetBean(FACTORY_BEAN_PREFIX + beanName, FactoryBean.class, null, true); return getTypeForFactoryBean(factoryBean); } catch (BeanCreationException ex) { // Can only happen when getting a FactoryBean. if (logger.isDebugEnabled()) { logger.debug("Ignoring bean creation exception on FactoryBean type check: " + ex); } onSuppressedException(ex); return null; } }
這里捕獲異常后,直接 return null導致異常被吞。
對于一對一和多對一(mybatis映射為一對一)。查詢的時候一起查詢即可。
但是對于一對多,和多對多。也許那個多對應的數據很多,而我們不需要那個多。那么一起查詢會浪費性能資源。
所以,mybatis有懶加載。
mysql默認是立即加載。
懶加載在Collection或者association屬性中有一個fetchType屬性,eager立即加載。lazy懶加載。
<settings> <!--延遲加載總開關--> <setting name="lazyLoadingEnabled" value="true"/> <!--侵入式延遲加載開關--> <!--3.4.1版本之前默認是true,之后默認是false--> <setting name="aggressiveLazyLoading" value="false"/> <!--如果不寫這個,可能有問題--> <setting name="lazyLoadTriggerMethods" value=""/> </settings>
感謝各位的閱讀,以上就是“mybatis一直加載xml怎么解決”的內容了,經過本文的學習后,相信大家對mybatis一直加載xml怎么解決這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。