java - 将 PostgreSQL 查询转换为 DSLContext 的问题

标签 java sql postgresql jooq

我正在尝试使用 jOOq 将我从命令行编写和测试的查询转换为 DSLContext 查询,但遇到了问题。下面的查询旨在从具有 JSONB 列“tags”的表“campaign”中返回匹配 like 参数和通配符的标签列表。此列的值按以下方式格式化:

[“狗”,“猫”,“兔子”]

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

最佳答案

您的查询将转换为 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();

关于java - 将 PostgreSQL 查询转换为 DSLContext 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39007389/

相关文章:

mysql - 大型 SQL 数据库删除重复行

java - 如何在对话期间以编程方式将号码输入到android中的电话应用程序屏幕

java - 如何解决连接mssql时JNDI错误

mysql - 删除至少一个为空的多个表

sql - 从触发器插入没有发生?

java - 如何使用 Postgresql 数据库在 Heroku 上部署?

postgresql - 从标准输入复制 CSV 文件会抛出 "missing data for column"

java - 使用 Jest 或 Java API 有没有办法告诉 Elasticsearch 从 json 创建文档作为字符串?

java - 无法在我的 Spring Web 应用程序中注入(inject) Activiti 框架服务

mysql - 为什么当我上传 csv 文件时,数据库中的某一列中的数字不断变化?