2016-08-17 3 views
1

Я пытаюсь преобразовать запрос, который я написал и протестировал из командной строки, в запрос DSLContext, используя jOOq и сталкиваясь с проблемами. Следующий запрос предназначен для возврата списка тегов, которые соответствуют аналогичному параметру, с шаблоном из таблицы «кампания» с столбцом «теги» JSONB. Этот столбец содержит значения, отформатированные следующим образом:Ошибка преобразования запроса PostgreSQL в DSLContext

[ «собаки», «Кошки», «кролики»]

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

Я пытаюсь создать это в DSLContext следующим образом, но я получаю ошибка «ERROR: аргумент 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(); 

ответ

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(); 
+0

Спасибо! Похоже, что это работает. Ты спасатель – thurmc