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

引入mybatis-plus報(bào) Invalid bound statement錯(cuò)誤問題的解決方法

 更新時(shí)間:2020年05月29日 15:28:19   作者:鄙人薛某  
這篇文章主要介紹了引入mybatis-plus報(bào) Invalid bound statement錯(cuò)誤問題的解決方法,需要的朋友可以參考下

錯(cuò)誤

Mybatis-Plus (簡稱MP) 是mybatis的一個(gè)增強(qiáng)工具,在mybatis的基礎(chǔ)上只做增強(qiáng)不做改變,簡化了開發(fā)效率。其實(shí)就是幫我們封裝了一些簡單的curd方法,可以直接調(diào)用,不必再重寫這些簡單的sql語句,類似JPA那樣。

前兩天創(chuàng)建了一個(gè)新項(xiàng)目,持久層框架用的是mybatis,同時(shí)引入mybatis-plus做增強(qiáng)工具,項(xiàng)目啟動(dòng)后,調(diào)用接口卻發(fā)現(xiàn)報(bào)錯(cuò)了,報(bào)錯(cuò)的提醒如下:

在這里插入圖片描述

錯(cuò)誤的信息顯示的是 “無效的綁定語句“,報(bào)錯(cuò)的地方正是操作sql語句的方法,從網(wǎng)上查了一下答案,該錯(cuò)誤主要是數(shù)據(jù)源綁定的配置問題,于是我順騰摸瓜,從配置數(shù)據(jù)源的地方下手。

查找原因

因?yàn)轫?xiàng)目是做了多數(shù)據(jù)源的讀寫分離,所以我把數(shù)據(jù)源的動(dòng)態(tài)配置整合到了一個(gè)類DataSourceConfig中,這是該類的代碼:

@Configuration
@MapperScan(basePackages = "com.xjt.proxy.mapper", sqlSessionTemplateRef = "sqlTemplate")
public class DataSourceConfig {
 /**
  * 主庫
  */
 @Bean
 @ConfigurationProperties(prefix = "spring.datasource.master")
 public DataSource masterDb() {
  return DruidDataSourceBuilder.create().build();
 }

 /**
  * 從庫
  */
 @Bean
 @ConfigurationProperties(prefix = "spring.datasource.slave")
 public DataSource slaveDb() {
  return DruidDataSourceBuilder.create().build();
 }

 /**
  * 主從動(dòng)態(tài)配置
  */
 @Bean
 public DynamicDataSource dynamicDb(@Qualifier("masterDb") DataSource masterDataSource,
          @Autowired(required = false) @Qualifier("slaveDb") DataSource slaveDataSource) {
  DynamicDataSource dynamicDataSource = new DynamicDataSource();
  Map<Object, Object> targetDataSources = new HashMap<>();
  targetDataSources.put(DynamicDataSourceEnum.MASTER.getDataSourceName(), masterDataSource);
  if (slaveDataSource != null) {
   targetDataSources.put(DynamicDataSourceEnum.SLAVE.getDataSourceName(), slaveDataSource);
  }
  dynamicDataSource.setTargetDataSources(targetDataSources);
  dynamicDataSource.setDefaultTargetDataSource(masterDataSource);
  return dynamicDataSource;
 }

 @Bean
 public SqlSessionFactory sessionFactory(@Qualifier("dynamicDb") DataSource dynamicDataSource) throws Exception {
  SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
  bean.setMapperLocations(
    new PathMatchingResourcePatternResolver().getResources("classpath*:mapper/*Mapper.xml"));
  bean.setDataSource(dynamicDataSource);
  return bean.getObject();
 }

 @Bean
 public SqlSessionTemplate sqlTemplate(@Qualifier("sessionFactory") SqlSessionFactory sqlSessionFactory) {
  return new SqlSessionTemplate(sqlSessionFactory);
 }

 @Bean(name = "dataSourceTx")
 public DataSourceTransactionManager dataSourceTx(@Qualifier("dynamicDb") DataSource dynamicDataSource) {
  DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager();
  dataSourceTransactionManager.setDataSource(dynamicDataSource);
  return dataSourceTransactionManager;
 }
}

內(nèi)容沒什么復(fù)雜的,主要是對主從庫的數(shù)據(jù)源配置映射,以及把數(shù)據(jù)源注入SqlSessionFactory對象中,如果對該部分代碼或者讀寫分離比較疑惑的話,可以看我之前的文章《讀寫分離很難嗎?springboot結(jié)合aop簡單就實(shí)現(xiàn)了》

主從庫映射數(shù)據(jù)源沒什么異議,想來想去應(yīng)該是注入那一步有問題,然后就把目光放到了sessionFactory方法上,該方法主要是返回一個(gè)SqlSessionFactory對象,該對象是由通過新建一個(gè)SqlSessionFactoryBean對象并注入數(shù)據(jù)源后返回的,問題應(yīng)該是出在這個(gè)SqlSessionFactoryBean類上,后來,經(jīng)平哥(我旁邊的大佬)提醒后,這里應(yīng)該要換成mybatis-plus中另一個(gè)Bean工廠類,叫做MybatisSqlSessionFactoryBean,點(diǎn)開該類的源碼,才發(fā)現(xiàn)該類正是拷貝了SqlSessionFactoryBean,并且重寫了自己的自定義加載方法buildSqlSessionFactory,

在這里插入圖片描述

跳轉(zhuǎn)到該方法的源碼中,發(fā)現(xiàn)其中有一段代碼比較重要,配置中少了這一步就會(huì)注入失敗,

在這里插入圖片描述

改動(dòng)

也就是說,注入數(shù)據(jù)源的地方還需要配置mapper的掃描路徑,如此一來,改動(dòng)的地方也比較明確了,就是注入數(shù)據(jù)源的地方把 SqlSessionFactoryBean 改成 MybatisSqlSessionFactoryBean 后,并配置mapper文件對應(yīng)的路徑,也就是把sessionFactory方法改成如下代碼:

@Bean
 public SqlSessionFactory sessionFactory(@Qualifier("dynamicDb") DataSource dynamicDataSource) throws Exception {
  MybatisSqlSessionFactoryBean sqlSessionFactoryBean = new MybatisSqlSessionFactoryBean();
  sqlSessionFactoryBean.setDataSource(dynamicDataSource);
  PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();  sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath*:mapper/*Mapper.xml"));
  return sqlSessionFactoryBean.getObject();
 }

這樣一來,再次啟動(dòng)項(xiàng)目就可以正常操作sql語句了。

總結(jié)

到此這篇關(guān)于引入mybatis-plus報(bào) Invalid bound statement錯(cuò)誤問題的解決方法的文章就介紹到這了,更多相關(guān)Mybatis plus Invalid bound statement內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java實(shí)現(xiàn)簡單銀行家算法

    java實(shí)現(xiàn)簡單銀行家算法

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡單銀行家算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • Java字符串替換的三種方法實(shí)際應(yīng)用

    Java字符串替換的三種方法實(shí)際應(yīng)用

    這篇文章主要給大家介紹了關(guān)于Java字符串替換的三種方法,replace和replaceAll是JAVA中常用的替換字符的方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • Java中Buffer緩沖區(qū)的ByteBuffer類詳解

    Java中Buffer緩沖區(qū)的ByteBuffer類詳解

    這篇文章主要介紹了Java中Buffer緩沖區(qū)的ByteBuffer類詳解,ByteBuffer類是Java NIO庫中的一個(gè)重要類,用于處理字節(jié)數(shù)據(jù),它提供了一種靈活的方式來讀取、寫入和操作字節(jié)數(shù)據(jù),ByteBuffer類是一個(gè)抽象類,可以通過靜態(tài)方法創(chuàng)建不同類型的ByteBuffer對象,需要的朋友可以參考下
    2023-10-10
  • Spring Cloud學(xué)習(xí)教程之DiscoveryClient的深入探究

    Spring Cloud學(xué)習(xí)教程之DiscoveryClient的深入探究

    這篇文章主要給大家介紹了關(guān)于Spring Cloud學(xué)習(xí)教程之DiscoveryClient的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-04-04
  • Java實(shí)現(xiàn)單鏈表SingleLinkedList增刪改查及反轉(zhuǎn) 逆序等

    Java實(shí)現(xiàn)單鏈表SingleLinkedList增刪改查及反轉(zhuǎn) 逆序等

    單鏈表是鏈表的其中一種基本結(jié)構(gòu)。一個(gè)最簡單的結(jié)點(diǎn)結(jié)構(gòu)如圖所示,它是構(gòu)成單鏈表的基本結(jié)點(diǎn)結(jié)構(gòu)。在結(jié)點(diǎn)中數(shù)據(jù)域用來存儲(chǔ)數(shù)據(jù)元素,指針域用于指向下一個(gè)具有相同結(jié)構(gòu)的結(jié)點(diǎn)。 因?yàn)橹挥幸粋€(gè)指針結(jié)點(diǎn),稱為單鏈表
    2021-10-10
  • 淺析Spring配置中的classpath:與classpath*:的區(qū)別

    淺析Spring配置中的classpath:與classpath*:的區(qū)別

    這篇文章主要介紹了Spring配置中的"classpath:"與"classpath*:"的區(qū)別,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Java定時(shí)器例子_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Java定時(shí)器例子_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    本文給大家分享了java定時(shí)器例子,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧
    2017-05-05
  • JAVA一個(gè)快速排序?qū)崿F(xiàn)代碼

    JAVA一個(gè)快速排序?qū)崿F(xiàn)代碼

    排序有哪幾種方法?請列舉。并用JAVA實(shí)現(xiàn)一個(gè)快速排序.,需要的朋友可以參考下
    2017-02-02
  • 關(guān)于SpringBoot中controller參數(shù)校驗(yàn)的使用

    關(guān)于SpringBoot中controller參數(shù)校驗(yàn)的使用

    本文主要介紹了關(guān)于SpringBoot中controller參數(shù)校驗(yàn)的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Sentinel核心類之Entry類解讀

    Sentinel核心類之Entry類解讀

    這篇文章主要介紹了Sentinel核心類之Entry類解讀,Sentinel中Entry可以理解為每次進(jìn)入資源的一個(gè)憑證,如果調(diào)用SphO.entry()或者SphU.entry()能獲取Entry對象,代表獲取了憑證,沒有被限流,否則拋出一個(gè)BlockException,需要的朋友可以參考下
    2023-12-12

最新評論