SpringBoot Mybatis如何配置多數(shù)據(jù)源并分包
看了不少網(wǎng)上關(guān)于多數(shù)據(jù)源的配置,大致可分為兩類(lèi),分包方式和通過(guò)切面方式;
樣例已上傳至github:https://github.com/dadachao/multids
第一個(gè)子項(xiàng)目ds01即時(shí)使用分包方式完成多數(shù)據(jù)源配置。
總結(jié)項(xiàng)目中出現(xiàn)的問(wèn)題和解決辦法:
數(shù)據(jù)庫(kù)的連接信息:
連接信息是寫(xiě)在db.properties文件中的:
#數(shù)據(jù)庫(kù)ds1spring.datasource.ds1.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.ds1.url=jdbc:mysql://localhost:3306/ds1?serverTimezone=UTCspring.datasource.ds1.username=rootspring.datasource.ds1.password=root#數(shù)據(jù)庫(kù)ds2spring.datasource.ds2.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.ds2.url=jdbc:mysql://localhost:3306/ds2?serverTimezone=UTCspring.datasource.ds2.username=rootspring.datasource.ds2.password=root
這些信息將在配置類(lèi)DbConfig1.java中引用。一開(kāi)始我是通過(guò)使用注解@ImportResource(...)引進(jìn)db.properties文件,但在運(yùn)行時(shí)報(bào)了org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 1; 前言中不允許有內(nèi)容的錯(cuò)誤;使用這個(gè)注解也是我瞎猜的。后是通過(guò)使用注解@PropertySource(value = 'classpath:/db.properties',encoding = 'utf-8')解決問(wèn)題。
其次是關(guān)于在配置類(lèi)中使用@ConfigurationProperties注解自動(dòng)注入連接信息值(value)的問(wèn)題:spring.datasource.ds1.url=jdbc:mysql://localhost:3306/ds1?serverTimezone=UTC
注意要使用.url而不是.jdbc-url;
指定數(shù)據(jù)連接池類(lèi)型DataType:
數(shù)據(jù)源類(lèi)型可以在配置類(lèi)生成DataSource的方法中指定:
@Bean(name = 'ds1DataSource') @Primary @ConfigurationProperties(prefix = 'spring.datasource.ds1') public DataSource getDataSource(){ DataSourceBuilder<?> dataSourceBuilder = DataSourceBuilder.create(); dataSourceBuilder.type(com.alibaba.druid.pool.DruidDataSource.class); return dataSourceBuilder.build(); }
指定***Mapper.xml文件的路徑掃描問(wèn)題:(相當(dāng)重要)
使用配置類(lèi)進(jìn)行數(shù)據(jù)源相關(guān)進(jìn)行配置后,原先在application.yml中配置的相關(guān)參數(shù)就不起作用了(原因未知),原先我是在application.yml中配置了.xml文件的掃描路徑:
mybatis:mapper-locations: classpath:/mybatis/**/*.xmltype-aliases-package: com.kong.ds01.model
但在運(yùn)行時(shí)報(bào)錯(cuò):Mapper Bound Error(not found);后來(lái)通過(guò)在配置類(lèi)中寫(xiě)入掃描路徑解決:
public final static String mapperXmlLocation = 'classpath:mybatis/*/*.xml';@Bean(name = 'ds1SqlSessionFactory') @Primary public SqlSessionFactory getSqlSessionFactory(@Qualifier('ds1DataSource') DataSource dataSource) throws Exception { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(dataSource); sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(mapperXmlLocation)); return sqlSessionFactoryBean.getObject(); }
而且通過(guò)這種方法表示任意路徑不能使用/**/,要使用/*/,否則識(shí)別不出來(lái)又會(huì)報(bào)相同的錯(cuò)誤,這點(diǎn)真是太坑了!
指定執(zhí)行器的類(lèi)型(Execute.Type):
可以通過(guò)在配置類(lèi)中的sqlSessionTemplate中指定:
@Bean(name = 'ds1SqlSessionTemplate') @Primary public SqlSessionTemplate getSqlSessionTemplate(@Qualifier('ds1SqlSessionFactory') SqlSessionFactory sqlSessionFactory){ return new SqlSessionTemplate(sqlSessionFactory, ExecutorType.BATCH); }
指定為BATCH類(lèi)型后在進(jìn)行批量操作時(shí)效率有明顯的提高。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ThinkPHP5 通過(guò)ajax插入圖片并實(shí)時(shí)顯示(完整代碼)2. ASP.NET MVC通過(guò)勾選checkbox更改select的內(nèi)容3. Android實(shí)現(xiàn)圖片自動(dòng)切換功能(實(shí)例代碼詳解)4. jsp+mysql實(shí)現(xiàn)網(wǎng)頁(yè)的分頁(yè)查詢5. Python使用oslo.vmware管理ESXI虛擬機(jī)的示例參考6. 存儲(chǔ)于xml中需要的HTML轉(zhuǎn)義代碼7. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁(yè)8. 解決Python paramiko 模塊遠(yuǎn)程執(zhí)行ssh 命令 nohup 不生效的問(wèn)題9. JavaScript Tab菜單實(shí)現(xiàn)過(guò)程解析10. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟
