如何使用 Hibernate Criteria 在 Postgresql JSON 中进行搜索并与横向一起使用

Opt*_*tio 5 java postgresql json hibernate hibernate-criteria

在客户端,我们有使用过滤器搜索的端点。

在后端,我有在 Postgresql DB 中搜索的方法。选项之一 - 搜索 jsonb 字段。

在这一天之前,我搜索了valueskeys。我的代码是:

if (appFilter.getSearchValue() != null) {
    criteria.add(Restrictions.sqlRestriction("UPPER(values::text) LIKE '%" + appFilter.getSearchValue().toUpperCase() + "%'"));
}
Run Code Online (Sandbox Code Playgroud)

SQL 模拟(UPPER- 不是强制性的):

SELECT *
FROM application
WHERE UPPER(values :: TEXT) LIKE '%some text%'
Run Code Online (Sandbox Code Playgroud)

现在我需要搜索values。用于此目的的 SQL 查询:

SELECT *
FROM application, LATERAL json_each_text(application.values :: JSON)
WHERE value :: TEXT LIKE '%some text%';
Run Code Online (Sandbox Code Playgroud)

我如何将其添加到限制中?也许还有其他用于搜索值的变体?休眠 5.0.12

小智 2

Restrictions.sqlRestriction 将在 WHERE 子句之后使用 AND 插入到生成的 sql 中,因此您需要添加如下内容

criteria.add(Restrictions.sqlRestriction("this_.id IN (SELECT application.id FROM application , LATERAL json_each_text(values :: JSON) WHERE UPPER(value :: TEXT) LIKE '%" + appFilter.getSearchValue().toUpperCase() +"%')"));
Run Code Online (Sandbox Code Playgroud)