Проблема с преобразованием запроса PostgreSQL в DSLContext

Я пытаюсь преобразовать запрос, который я написал и протестировал из командной строки, в запрос DSLContext с использованием jOOq, и у меня возникают проблемы. Приведенный ниже запрос предназначен для возврата списка тегов, соответствующих аналогичному параметру с подстановочным знаком из таблицы "campaign" со столбцом JSONB "tags". Этот столбец имеет значения, отформатированные следующим образом:

["собаки","кошки","кролики"]

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

Я пытаюсь создать это в DSLContext следующим образом, но получаю сообщение об ошибке «ОШИБКА: аргумент AND не должен возвращать набор». Может ли кто-нибудь увидеть, что я могу сделать, чтобы решить эту проблему и получить те же результаты из моего запроса 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();

person thurmc    schedule 17.08.2016    source источник


Ответы (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();
person Lukas Eder    schedule 18.08.2016
comment
Спасибо! Похоже, это работает. Ты спасатель - person thurmc; 18.08.2016