带有 JOOQ 的 Spring Boot 收到一条消息“需要一个找不到的 'org.jooq.DSLContext' 类型的 bean”
Posted
技术标签:
【中文标题】带有 JOOQ 的 Spring Boot 收到一条消息“需要一个找不到的 \'org.jooq.DSLContext\' 类型的 bean”【英文标题】:Spring boot with JOOQ got a message "required a bean of type 'org.jooq.DSLContext' that could not be found"带有 JOOQ 的 Spring Boot 收到一条消息“需要一个找不到的 'org.jooq.DSLContext' 类型的 bean” 【发布时间】:2018-08-13 09:41:45 【问题描述】:我使用 spring boot 和 JOOQ 创建了一个简单的项目,添加了依赖项“spring-boot-starter-jooq”。编译时应用程序启动失败。
这里是 pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.bingo</groupId>
<artifactId>api</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>api</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jooq</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.hashids</groupId>
<artifactId>hashids</artifactId>
<version>1.0.1</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>18.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.jooq</groupId>
<artifactId>jooq-codegen-maven</artifactId>
<configuration>
<jdbc>
<driver>com.mysql.jdbc.Driver</driver>
<url>jdbc:mysql://123.123.123.123:3306/dbname</url>
<user>root</user>
<password>password</password>
</jdbc>
<generator>
<database>
<name>org.jooq.util.mysql.MySQLDatabase</name>
<includes>.*</includes>
<excludes></excludes>
<inputSchema>dbname</inputSchema>
<forcedTypes>
<forcedType>
<name>CustomUUID</name>
<types>binary.*</types>
</forcedType>
<forcedType>
<name>Geometry</name>
<types>(geometry|GEOMETRY)</types>
</forcedType>
</forcedTypes>
<properties>
<property>
<key>packages</key>
<value>com.bingo.api.entity</value>
</property>
</properties>
</database>
<generate>
<pojos>true</pojos>
</generate>
</generator>
</configuration>
</plugin>
</plugins>
</build>
</project>
这是我要注入 DSLContext 的地方:
@Service
public class GameDao
private final DSLContext create;
@Autowired
public GameDao(DSLContext dslContext)
this.create = dslContext;
错误信息:
在上下文初始化期间遇到异常 - 取消刷新尝试:org.springframework.beans.factory.UnsatisfiedDependencyException:在文件 [/Users/yangzhiwei/Downloads/BingoApi/target/classes/com/ 中定义名称为“gameDao”的 bean 创建错误bingo/api/dao/GameDao.class]:通过构造函数参数0表示的不满足依赖;嵌套异常是 org.springframework.beans.factory.NoSuchBeanDefinitionException:没有“org.jooq.DSLContext”类型的合格 bean 可用:预计至少有 1 个有资格作为自动装配候选者的 bean。依赖注释:
/*********************************
应用程序启动失败
/*********************************
说明:com.bingo.api.dao.GameDao 中构造函数的参数 0 需要一个无法找到的 'org.jooq.DSLContext' 类型的 bean。 行动:考虑在你的配置中定义一个“org.jooq.DSLContext”类型的bean。
有什么帮助吗?
更新: 1.我在application.properties文件中添加了这样的属性:
spring.datasource.url==jdbc:mysql://123.123.123.123:3306/bingo
spring.datasource.user=username
spring.datasource.password=password
2.我添加了 jooqConfiguration 类。 现在又收到一条错误消息:
Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'jooqConfiguration': Unsatisfied dependency expressed through field 'dataSource'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'javax.sql.DataSource' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: @org.springframework.beans.factory.annotation.Autowired(required=true)
***************************
APPLICATION FAILED TO START
***************************
Description:
Field dataSource in com.bingo.api.config.JooqConfiguration required a bean of type 'javax.sql.DataSource' that could not be found.
- Bean method 'dataSource' not loaded because @ConditionalOnProperty (spring.datasource.jndi-name) did not find property 'jndi-name'
- Bean method 'dataSource' not loaded because @ConditionalOnClass did not find required class 'javax.transaction.TransactionManager'
【问题讨论】:
spring.datasource
配置应该足够了。你有一个额外的=
登录spring.datasource.url
。
【参考方案1】:
你需要实例化DSLContext
。
首先添加属性:
spring.datasource.url=jdbc:h2:~/jooq
spring.datasource.username=sa
spring.datasource.password=xxx
编辑:根据 jhyot 的评论...添加配置应该足够好,因为 JooqAutoConfiguration
将为您创建 DSLContext
。
可选:添加配置以创建 DSLContext bean。这是一个例子。
@Configuration
public class JooqConfiguration
@Autowired
private DataSource dataSource;
@Bean
public DataSourceConnectionProvider connectionProvider()
return new DataSourceConnectionProvider
(new TransactionAwareDataSourceProxy(dataSource));
@Bean
public DefaultDSLContext dsl()
return new DefaultDSLContext(configuration());
public DefaultConfiguration configuration()
DefaultConfiguration jooqConfiguration = new DefaultConfiguration();
jooqConfiguration.set(connectionProvider());
jooqConfiguration
.set(new DefaultExecuteListenerProvider(exceptionTransformer()));
return jooqConfiguration;
参考:http://www.baeldung.com/spring-boot-support-for-jooq
【讨论】:
您实际上不需要创建 DSLContext 实例并自己配置它。 Spring Boot 会为你做这件事。看看 JooqAutoConfiguration.java。但是您可能确实需要在 Spring Boot 加载 DSLContext 之前提供您的 DB 配置并将 DB 驱动程序放在类路径中。 @jhyot 是的,你是对的。我更新了我的答案。谢谢 感谢您的帮助。我添加了属性和 jooqConfiguration 类,但收到了另一条错误消息。我更新了问题。 您是否按照我提供的链接中的第 4 步操作? @JoseMartinez 我重新安装了 JDK,然后问题得到解决。其实不知道原因。谢谢。【参考方案2】:使用 Spring Boot 2.4 或 2.5 和 jOOQ 3.15+ 的人可能会遇到此消息的一个原因:
没有可用的“org.jooq.DSLContext”类型的合格 bean:预计至少有 1 个符合自动装配候选资格的 bean。
... 是因为 jOOQ 3.15 有一个新的 R2DBC 依赖项,而 Spring Boot 2.4 / 2.5 还没有为与 JDBC 和 R2DBC 一起工作的第三方做好准备,另请参阅 How to fix "Consider defining a bean of type 'org.jooq.DSLContext' in your configuration." after update to jOOQ 3.15.0
大多数用户没有使用 R2DBC,因此您可以排除 R2dbcAutoConfiguration
(注意拼写错误。它不是 R2dbcDataAutoConfiguration
):
@SpringBootApplication(exclude = R2dbcAutoConfiguration.class )
【讨论】:
以上是关于带有 JOOQ 的 Spring Boot 收到一条消息“需要一个找不到的 'org.jooq.DSLContext' 类型的 bean”的主要内容,如果未能解决你的问题,请参考以下文章
Spring boot Flyway Jooq Code gen maven 插件顺序
如何使用 Spring-Boot config 配置 JOOQ 设置?
jooQ spring boot Multiple Schema(读写拆分)
Spring Boot with JOOQ 和 Spring Data JPA 之间的技术差异