当前位置: 首页 > 知识库问答 >
问题:

带有JOOQ的Spring boot收到一条消息“需要一个找不到的'org.JOOQ.DSLContext'类型的bean”

吕霍英
2023-03-14

我创建了一个简单的项目,带有Spring Boot和JOOQ,添加了依赖项“spall-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>

这就是我想要注入上下文的地方:

@Service
public class GameDao {
    private final DSLContext create;
    @Autowired
    public GameDao(DSLContext dslContext) {
        this.create = dslContext;
    }
}

错误消息:

上下文初始化期间遇到异常-取消刷新尝试:org。springframework。豆。工厂UnsatisfiedPendencyException:创建名为“gameDao”的bean时出错,该bean在文件[/Users/yangzhiwei/Downloads/BingoApi/target/classes/com/bingo/api/dao/gameDao.class]中定义:通过构造函数参数0表示未满足的依赖关系;嵌套的异常是org。springframework。豆。工厂NoSuchBean定义异常:没有“org”类型的合格bean。约克。DSLContext'可用:至少需要1个符合autowire候选条件的bean。依赖项注释:{}

/***************************

应用程序无法启动

/***************************

描述:com中构造函数的参数0。答对 了应用程序编程接口。刀。GameDao需要一个“org”类型的bean。约克。无法找到的“上下文”。动作:考虑定义一个类型为“org”的bean。约克。在您的配置中使用“上下文”。

有什么可以帮忙的吗?

更新:1.我在application.properties文件中添加了如下属性:

spring.datasource.url==jdbc:mysql://123.123.123.123:3306/bingo
spring.datasource.user=username
spring.datasource.password=password

2、我添加了jooqConfigsion类,现在又收到一条错误消息:

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'

共有2个答案

利海阳
2023-03-14

在jOOQ 3.15中使用Spring Boot 2.4或2.5的用户可能会遇到以下消息:

没有“org”类型的合格bean。约克。DSLContext'可用:至少需要1个符合autowire候选条件的bean。

... 因为jOOQ 3.15有一个新的R2DBC依赖项,Spring Boot 2.4/2.5还没有为同时使用JDBC和R2DBC的第三方做好准备,请参阅如何修复“考虑在配置中定义'org.jOOQ.DSLContext'类型的bean”更新至jOOQ 3.15.0后

大多数用户都没有使用R2DBC,所以您可以排除R2dbcAutoConfiguration(注意输入错误。这不是R2DBCDATA自动配置):

@SpringBootApplication(exclude = { R2dbcAutoConfiguration.class })
许毅
2023-03-14

您需要实例化DSLContext

首先添加属性:

spring.datasource.url=jdbc:h2:~/jooq
spring.datasource.username=sa
spring.datasource.password=xxx

编辑:根据jhyot的评论。。。添加配置应该足够好,因为DSLContext将通过JooqAutoConfiguration为您创建。

可选:添加配置以创建DSLContextbean。下面是一个例子。

@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

 类似资料:
  • 我用spring boot和JOOQ创建了一个简单的项目,添加了依赖项“spring-boot-starter-jooq”。编译时应用程序启动失败。 下面是pom.xml: 这就是我要注入DSLContext的地方: 应用程序启动失败 /****************************** 描述:com.bingo.api.dao.Gamedao中的构造函数的参数0需要一个类型为“org.

  • 我搜索了很多stackoverflow,但没有找到解决问题的方法。当将SpringBoot应用程序作为WAR文件部署到Tomcat 8时,我发现以下错误,在本地它确实可以正常工作 有一个接口 和两个实现类 和二等舱 还有Rest服务 所以我不明白Tomcat怎么找不到像boolean这样的原始数据类型,也不明白为什么我在本地运行它时它能工作。 任何帮助都将不胜感激 问候马蒂亚斯

  • 使用mvn spring boot启动时:run或甚至使用gradle返回该问题。 这里是主要的类,在我看来所有的需求都可以,我使用的是org.springframework.boot版本1.5.7 以及: 使用Maven或Gradle会返回相同的问题。所有注释和包名称似乎都符合要求。

  • 以下是服务: 下面是映射器:

  • 我正在开发Spring Boot应用程序,在启动服务器时遇到了这个错误。我不确定是否错误地定义了任何注释或缺少任何依赖项。任何帮助都将不胜感激。 主要类: UserService类: UserDAO类: @repository公共类UserDAO实现IUserDAO{ Build.gradle: 错误消息: 我看到了所有相关的答案,并尝试实现这些建议,如添加依赖项、在主类中添加符号等。但它显示了相

  • 编辑-更新:我根据本教程创建了一个全新的项目,我注意到,在配置pom后,问题是如果我添加 应用程序类的注释。 我是Spring Boot的新手,我已经创建了一个具有持久性的简单工作应用程序,现在我试图添加Spring security jwt,但它不起作用。 以下是我的项目结构: 在为安全性添加依赖项之前,它在持久性方面都工作得很好,现在是这样。我错过了什么?