微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java-Jooq无法找到postgres数据库的驱动程序

我有一个使用gradle,postgres和jooq的spring-boot应用程序.
我希望Jooq的代码生成器为我创建类,但是在gradle clean build期间,我遇到了与驱动程序有关的错误

java.lang.ClassNotFoundException:org.postgresql.Driver

我不明白为什么找不到驱动程序.这是我的gradle.build文件的一些相关方面:

plugins {
    id "org.springframework.boot" version "2.0.2.RELEASE"
    id 'nu.studer.jooq' version '3.0.1'
}

我使用的是Spring Boot的2.0.2.RELEASE版本.这是我的依赖项:

dependencies {
    implementation "org.springframework.boot:spring-boot-starter-web:$SPRING_VERSION"
    implementation "org.springframework.boot:spring-boot-starter-actuator:$SPRING_VERSION"
    implementation "org.springframework.boot:spring-boot-starter-jooq:$SPRING_VERSION"
    implementation "org.springframework.boot:spring-boot-starter-data-jpa:$SPRING_VERSION"
    implementation "org.springframework.boot:spring-boot-starter-jooq:$SPRING_VERSION"
 implementation 'org.postgresql:postgresql:42.2.5'

}

这是我在gradle文件中拥有的Jooq配置

jooq {
   myApp(sourceSets.main) {
       jdbc {
           driver = 'org.postgresql.Driver'
           url = "jdbc:postgresql://${db_host}:${db_port}/${db_name}"
           user = "${db_username}"
           password = "${db_password}"
           schema = 'public'
       }
       generator {
           name = 'org.jooq.util.DefaultGenerator'
           strategy {
               name = 'org.jooq.util.DefaultGeneratorStrategy'
           }
           database {
               name = 'org.jooq.util.postgres.PostgresDatabase'
               inputSchema = 'public'
           }
           generate {
               relations = true
               deprecated = false
               records = true
               immutablePojos = false
               fluentSetters = true
           }
           target {
               packageName = 'com.mycompany.mayapp.model.jooq'
               directory = 'out/production/classes/generated'
           }
       }
   }
}```


解决方法:

gradle-jooq-plugin需要在单独的配置中进行依赖.它使用jooqRuntime配置来检测所需的依赖关系,而不使用编译或实现配置.

将以下内容添加到您的依赖项中应该可以解决问题

jooqRuntime 'org.postgresql:postgresql:42.2.5'

这样,插件可以选择驱动程序并生成模型类.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐