SpringBoot+Mybatis配置多数据源,分包方式

看了不少网上关于多数据源的配置,大致可分为两类,分包方式和通过切面方式;

第一个子项目ds01即时使用分包方式完成多数据源配置。

总结项目中出现的问题和解决办法:

数据库的连接信息:

连接信息是写在db.properties文件中的:

这些信息将在配置类DbConfig1.java中引用。一开始我是通过使用注解@ImportResource(…)引进db.properties文件,但在运行时报了 org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 1;_前言中不允许有内容的错误;使用这个注解也是我瞎猜的。后是通过使用注解 @PropertySource(value = “classpath:/db.properties”,encoding = “utf-8”)_解决问题。

其次是关于在配置类中使用@ConfigurationProperties注解自动注入连接信息值(value)的问题:spring.datasource.ds1.url=jdbc:mysql://localhost:3306/ds1?serverTimezone=UTC

注意要使用.url而不是.jdbc-url;

指定数据连接池类型DataType:

数据源类型可以在配置类生成DataSource的方法中指定:

指定Mapper.xml文件的路径扫描问题:(相当重要)*

使用配置类进行数据源相关进行配置后,原先在application.yml中配置的相关参数就不起作用了(原因未知),原先我是在application.yml中配置了.xml文件的扫描路径:

但在运行时报错:Mapper Bound Error(not found);后来通过在配置类中写入扫描路径解决:

而且通过这种方法表示任意路径不能使用/*/,要使用//,否则识别不出来又会报相同的错误,这点真是太坑了!

指定执行器的类型(Execute.Type):

可以通过在配置类中的sqlSessionTemplate中指定:

指定为BATCH类型后在进行批量操作时效率有明显的提高。

Original: https://www.cnblogs.com/kongieg/p/12824606.html
Author: kongieg
Title: SpringBoot+Mybatis配置多数据源,分包方式

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/586799/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球