YML配置数据源

YML配置数据源

#由于pom.xml文件中添加jdbc的依赖包,所以该行必须配置
spring:
datasource:
#该驱动一般适用低版本的驱动链接. driver-class-name: com.mysql.jdbc.Driver
#如果使用最新版本的驱动则配置如下
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/jtdb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
username: root
password: root

url配置信息说明

1.serverTimezone=GMT%2B8 配置时区 GMT “%2B”—>+ 8

2.useUnicode=true 是否使用unicode编码 必须添加

3.characterEncoding=utf8 字符集编码格式 utf-8编码

4.autoReconnect=true 是否断线自动重连.

5.allowMultiQueries=true 是否允许mybatis执行多个sql

按照规则默认条件如下: 每个标签只能允许编辑一行有效sql

insert into user (id) values(1)
insert into user (id) values(1) mybatis必然报错!!!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在application.yml配置数据源,你可以按照以下方式进行设置: ```yaml spring: datasource: primary: url: jdbc:mysql://localhost:3306/primary_db username: primary_user password: primary_password secondary: url: jdbc:mysql://localhost:3306/secondary_db username: secondary_user password: secondary_password # 配置数据源 mybatis: configuration: # 设置驼峰命名规则 map-underscore-to-camel-case: true mapper-locations: classpath:mapper/*.xml # 配置数据源切换 datasource: primary: primary secondary: secondary ``` 在上面的配置中,我们定义了两个数据源:primary和secondary。你可以根据需求添加更多的数据源。 接下来,你需要在Spring Boot的配置类中创建两个数据源的Bean,并将它们注入到数据源路由器中: ```java @Configuration public class DataSourceConfig { @Bean(name = "primary") @ConfigurationProperties(prefix = "spring.datasource.primary") public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "secondary") @ConfigurationProperties(prefix = "spring.datasource.secondary") public DataSource secondaryDataSource() { return DataSourceBuilder.create().build(); } @Bean @Primary public DataSourceRouting dataSource(@Qualifier("primary") DataSource primaryDataSource, @Qualifier("secondary") DataSource secondaryDataSource) { Map<Object, Object> targetDataSources = new HashMap<>(); targetDataSources.put("primary", primaryDataSource); targetDataSources.put("secondary", secondaryDataSource); DataSourceRouting dataSourceRouting = new DataSourceRouting(); dataSourceRouting.setTargetDataSources(targetDataSources); dataSourceRouting.setDefaultTargetDataSource(primaryDataSource); return dataSourceRouting; } } ``` 在上面的代码中,我们创建了名为primary和secondary的数据源Bean,并使用@ConfigurationProperties注解设置它们的属性。然后,我们将这些数据源注入到DataSourceRouting中,并根据需要设置默认数据源。 最后,你需要创建一个数据源路由器(DataSourceRouting)的类,用于实现动态切换数据源的逻辑: ```java public class DataSourceRouting extends AbstractRoutingDataSource { @Override protected Object determineCurrentLookupKey() { return DataSourceContextHolder.getDataSource(); } } ``` 在上面的代码中,我们重写了determineCurrentLookupKey()方法,通过DataSourceContextHolder获取当前线程的数据源标识,并返回给Spring框架。 通过以上步骤,你就成功配置了多数据源。在需要切换数据源的地方,你可以使用DataSourceContextHolder.setDataSource("primary")或DataSourceContextHolder.setDataSource("secondary")来切换数据源。记得在每次请求结束后,使用DataSourceContextHolder.clearDataSource()来清除数据源标识,以免影响其他请求的数据源切换。 希望以上信息能够帮助到你!如有疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值