将PostgreSQL查询转换为DSLContext的问题

时间:2016-08-17 22:47:00

标签: java sql postgresql jooq

我正在尝试将使用jOOq从命令行编写和测试的查询转换为DSLContext查询,并且遇到问题。下面的查询旨在返回一个与like参数匹配的标记列表,其中包含来自表格" campaign"使用JSONB列"标记"。此列具有以下列方式格式化的值:

["狗""猫""兔"]

select distinct A.value 
from campaign T, LATERAL jsonb_array_elements_text(T.tags) A 
where A.value LIKE 't%'

我试图以下列方式将其创建为DSLContext,但是我收到错误" ERROR:AND的参数不能返回一个set"。任何人都可以看到我可以做些什么来解决这个问题,并从我的PostgreSQL查询和我的DSL查询产生相同的结果?

final Field<String> tagField = field("jsonb_array_elements_text(tags)", String.class);

final Table<Record1<String>> lateral = 
    lateral(sql.dsl().select(a).from(CAMPAIGN)).asTable();

final Result<Record1<String>> tag = sql.dsl()
.select(tagField)
.from(CAMPAIGN, lateral)
.where(tagField.like("t"))
.fetch();

1 个答案:

答案 0 :(得分:1)

您的查询将转换为jOOQ:

Field<String> value = field(name("A", "value"), String.class);
sql.dsl()
   .selectDistinct(value)
   .from(
        CAMPAIGN, 
        lateral(table("jsonb_array_elements_text({0})", CAMPAIGN.TAGS)).as("A"))
   .where(value.like("t%"))
   .fetch();