2016-08-17 14 views
1

私が書いたテストをコマンドラインからj100qを使用してDSLContextクエリに変換しようとしていますが、問題が発生しています。以下のクエリは、likeパラメータと一致するタグのリストを、JSONB列の "tags"を持つテーブル "campaign"のワイルドカードで返します。この列には、次のようにフォーマットされた値があります。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

関連する問題