springboot 2.x 多数据源配置出现jdbcUrl is required with driverClassName.

在SpringBoot 2.x中配置多数据源时遇到jdbcUrl is required with driverClassName的问题。解决方案是将配置项spring.datasource.url更改为spring.datasource.jdbc-url,以此修正错误。
摘要由CSDN通过智能技术生成

springboot 2.x 多数据源配置出现:

Caused by: java.lang.IllegalArgumentException: jdbcUrl is required with driverClassName.
	at com.zaxxer.hikari.HikariConfig.validate(HikariConfig.java:1059)
	at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:109)
	at org.springframework.jdbc.datasource.DataSourceUtils.fetchConnection(DataSourceUtils.java:151)
	at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:115)
	at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:78)
	at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:324)
	at org.springframework.boot.jdbc.EmbeddedDatabaseConnection.isEmbedded(EmbeddedDatabaseConnection.java:123)
	at org.springframework.boot.autoconfigure.orm.jpa.DataSourceInitializedPublisher.lambda$isInitializingDatabase$0(DataSourceInitializedPublisher.java:95)
	at org.springframework.boot.autoconfigure.orm
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中实现全局事务配置数据源配置可以通过整合 Spring Boot 和 Spring 的事务管理机制以及使用 Spring Boot 自带的数据库连接池实现。 以下是一个简单的示例,展示如何在 Spring Boot 中配置全局事务和数据源: 1. 在 pom.xml 文件中添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> ``` 2. 在 application.properties 文件中添加以下配置: ``` spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=root # JPA 配置 spring.jpa.show-sql=true spring.jpa.hibernate.ddl-auto=update # 全局事务配置 spring.transaction.default-timeout=60 spring.transaction.rollback-on-commit-failure=true spring.transaction.rollback-on-rollback-failure=true ``` 3. 在您的代码中添加以下注释: ``` @Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class) ``` 这将确保在事务方法中执行的所有操作都将在单个事务中进行,并在发生异常时回滚。 4. 在您的代码中使用 Spring Boot 自带的 JdbcTemplate 或 JPA 进行数据库操作。 ``` @Autowired private JdbcTemplate jdbcTemplate; public void insert() { jdbcTemplate.update("INSERT INTO users (name, age) VALUES (?, ?)", "Tom", 20); } ``` 或者 ``` @Autowired private UserRepository userRepository; public void insert() { User user = new User(); user.setName("Tom"); user.setAge(20); userRepository.save(user); } ``` 以上就是在 Spring Boot 中配置全局事务和数据源的示例。请注意,这只是一个简单的示例,实际实现可能会更复杂,具体实现取决于您的应用程序需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值