首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用jpa标准生成器在postgresql中将json列作为字符串?

如何使用jpa标准生成器在postgresql中将json列作为字符串?
EN

Stack Overflow用户
提问于 2022-01-14 17:57:45
回答 1查看 1.4K关注 0票数 3

我在表中有一个json列,如:

代码语言:javascript
运行
复制
    @Type(type = "jsonb")
    @Column(name = "json_data", columnDefinition = "json")
    private List<Persion> jsonData = Collections.emptyList();
代码语言:javascript
运行
复制
    public class Persion implements Serializable {
        private String name;

        private int age;

        private String sex;
    }

我想在json中查询包含特定名称的行,我编写了以下代码:

代码语言:javascript
运行
复制
    predicates.add(
            criteriaBuilder.like(
                criteriaBuilder.treat(root.get("jsonData"), String.class),
                "%" + name + "%"
        )
    )

但它抛出了异常:

代码语言:javascript
运行
复制
com.fasterxml.jackson.core.JsonParseException: Unexpected character ('%' (code 37)): expected a valid value (JSON String, Number, Array, Object or token 'null', 'true' or 'false')

我是否可以将json读入字符串,然后使用where条件进行查询?任何帮助都会很感激的。

EN

回答 1

Stack Overflow用户

发布于 2022-01-19 15:30:32

你可以试试这样的东西

代码语言:javascript
运行
复制
predicates.add(
        criteriaBuilder.like(
            criteriaBuilder.function("jsonb_extract_path_text", 
             String.class, root.get("jsonData"), 
             criteriaBuilder.literal("name")), "%" + name+ "%"
    )
)

我发现这些链接非常有用,How do I use spring data jpa to query jsonb column? Build predicates for a postgres jsonb column with criteria builder using JPA criteria

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70714742

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档