使用 jooq 和 gradle-jooq-plugin (kotlin) 生成代码

Code generation with jooq and gradle-jooq-plugin (kotlin)

我正在尝试将 jooq 与 gradle (kotlin) 一起使用。资料来源:gradle-jooq-plugin

我从昨天开始就在尝试,现在我没有任何资源可以看。

我想我没弄对,因为我是科特林的新手。但是这些例子对我也不起作用(我知道插件的解释很好,例子很简单..)

如果你们中的任何人能告诉我我做错了什么,我非常感谢,因为我很好奇。

以下是我的 build.gradle 文件的片段。我正在使用 Junit 5 进行测试(如果它有任何影响,我想不会

import nu.studer.gradle.jooq.JooqEdition

plugins {
    java
    jacoco // test coverage and reports
    id("org.springframework.boot") version "2.2.6.RELEASE"
    id("org.sonarqube") version "2.8"
    id("nu.studer.jooq") version "4.1"
    id("java-library")
    `kotlin-dsl`
}

apply(plugin = "io.spring.dependency-management")
apply(plugin = "nu.studer.jooq")

dependencies {
    apply(plugin = "nu.studer.jooq")

    // ### Spring ###
    implementation("org.springframework.boot:spring-boot-starter-web")
    implementation("org.springframework.boot:spring-boot-starter-jdbc")
    implementation("org.springframework.boot:spring-boot-starter-jooq")
    compileOnly("org.springframework.boot:spring-boot-starter-actuator")


    // ### Database ###
    implementation("org.postgresql:postgresql:42.2.11")
    implementation("org.liquibase:liquibase-core:3.8.8")
    implementation("org.jooq:jooq")
    jooqRuntime("postgresql:postgresql:9.1-901.jdbc4")

}

ext {
    jooq.version = "3.12.3"
}

java {
    sourceCompatibility = JavaVersion.VERSION_11
    targetCompatibility = JavaVersion.VERSION_11
}


jooq {
    version = "3.12.3"
    edition = JooqEdition.OSS

    "sample"(sourceSets["main"]) {

    }
}

我的问题

"sample"(sourceSets["main"]) 来自 here。一个 gradle (kotlin) 示例。但是我收到以下错误:

Expression '"sample"' of type 'String' cannot be invoked as a function. The function 'invoke()' is not found

在您的 jooq 配置中,您使用的示例函数设置为 string 而不是函数。

在此处查看文档:https://github.com/etiennestuder/gradle-jooq-plugin

你应该有这个:

jooq {
  version = '3.12.3'
  edition = 'OSS'
  generateSchemaSourceOnCompilation = true
  sample(sourceSets.main) {
    jdbc {
      driver = 'org.postgresql.Driver'
      url = 'jdbc:postgresql://localhost:5432/sample'
      user = 'some_user'
      password = 'secret'
      properties {
        property {
          key = 'ssl'
          value = 'true'
        }
      }
    }
    generator {
      name = 'org.jooq.codegen.DefaultGenerator'
      strategy {
        name = 'org.jooq.codegen.DefaultGeneratorStrategy'
        // ...
      }
      database {
        name = 'org.jooq.meta.postgres.PostgresDatabase'
        inputSchema = 'public'
        forcedTypes {
          forcedType {
            name = 'varchar'
            expression = '.*'
            types = 'JSONB?'
          }
          forcedType {
            name = 'varchar'
            expression = '.*'
            types = 'INET'
          }
        }
        // ...
      }
      generate {
        relations = true
        deprecated = false
        records = true
        immutablePojos = true
        fluentSetters = true
        // ...
      }
      target {
        packageName = 'nu.studer.sample'
        // directory = ...
      }
    }
  }
}

顺便说一句,为了让 Jooq 生成您的代码,您必须向它提供数据库的连接字符串。