使用 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 生成您的代码,您必须向它提供数据库的连接字符串。
我正在尝试将 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 生成您的代码,您必须向它提供数据库的连接字符串。