为了账号安全,请及时绑定邮箱和手机立即绑定

在 jooq 中设置 NULL 值

在 jooq 中设置 NULL 值

一只斗牛犬 2023-03-02 09:43:41
我有一个很大的查询,我的问题是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)但它没有用,因为它无法解析方法 with jooq.Param<String>。我该如何进行?
查看完整描述

1 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

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


// 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));

}

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


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


查看完整回答
反对 回复 2023-03-02
  • 1 回答
  • 0 关注
  • 190 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信