java - 在 jooq 中设置 NULL 值

标签 java mysql sql jooq

我有一个很大的查询,我的问题是设置 NULL使用 jooq 的值。 比如我有这样一段sql查询:

IF(t.PANEL_ID IS NULL, t.ID, NULL) AS testId

如果将其转换为 jooq 实现,将会出现如下内容:

when(TEST.PANEL_ID.isNull(), TEST.ID).otherwise(null)).as("testId")

但这是模棱两可的方法调用。

我做了一些研究,找到了这个片段:

DSL.val((String) null)

但它没有用,因为它无法用 jooq.Param<String> 解析方法.

我应该如何进行?

最佳答案

您的 NULL 表达式必须与您的 TEST.ID 列属于同一类型。我想这不是 String 列,而是一些数字列。无论实际数据类型如何,您始终可以使用另一个表达式的数据类型创建绑定(bind)值,例如

// Bind variable:
DSL.val(null, TEST.ID)

// Inline value / NULL literal
DSL.inline(null, TEST.ID)

如果你经常这样做,你也可以像这样提取你自己的实用程序:

public static <T> util(Field<?> nullable, Field<T> other) {
    return when(nullable.isNull(), other).otherwise(inline(null, other));
}

注意,jOOQ 有一个内置方法 NVL2 用于此目的:

nvl2(TEST.PANEL_ID, inline(null, TEST.ID), TEST.ID).as("testId")

关于java - 在 jooq 中设置 NULL 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56847906/

相关文章:

php - 将任何空输入转换为空字符串

mysql - SQLfiddle错误号: 150 - Foreign Key Issue

php - SQL 语法有问题

sql - Firebird 3 SQL 窗口函数 over()

java - 如何正确使用 setPriority() 方法?

java - TabPane 中的按钮使用 JavaFX

Java 如何处理对象中的 Array<MyItem> 的 "Unchecked cast"

java - 使用 grails 插件后,Grails 会从 Marshaller 抛出 ConverterException

mysql - 从大型 mysql 数据库中的另一个表更新列(700 万行)

sql - 编写 SQL Server case 语句