首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用于选择特定列的Spring Data JPA规范

用于选择特定列的Spring Data JPA规范
EN

Stack Overflow用户
提问于 2014-03-04 20:19:52
回答 3查看 22.6K关注 0票数 14

我们可以通过在Repository接口中编写自定义的@Query方法来选择特定的列。但是,我不想为不同的属性编写这么多方法。

我尝试过这样做,但它总是返回整个对象。

代码语言:javascript
运行
复制
public class MySpecifications {

    public static Specification<MyInfo> propertiesWithId(final String[] properties, final Object id, final String idProperty)
    {

        return new Specification<MyInfo>() {

            @Override
            public Predicate toPredicate(Root<MyInfo> root,
                    CriteriaQuery<?> query, CriteriaBuilder cb) {

                query = cb.createTupleQuery(); //tried cb.createQuery(MyInfo.class); as well

                List<Selection<? extends Object>> selectionList = new ArrayList<Selection<? extends Object>>();

                for (String property : properties) {

                    Selection<? extends Object> selection = root.get(property);

                    selectionList.add(selection);
                }

                return query.multiselect(selectionList).where(cb.equal(root.get(idProperty), id)).getRestriction();
            }

        };
    }
}

用作:

代码语言:javascript
运行
复制
MyInfo findOne(Specification(properties,idValue, idProperty));

这是正确的方式吗?错误在哪里?

EN

回答 3

Stack Overflow用户

发布于 2015-07-21 23:37:33

当前的spring data jpa规范执行器仅限于where子句中的条件,因此不能更改所选列,它隐含地仅限于完整实体(请查看JpaSpecificationExecutor接口文档)。您将不得不使用自定义存储库实现,或者移动到命名查询-

Spring Data JPA and Querydsl to fetch subset of columns using bean/constructor projection

票数 5
EN

Stack Overflow用户

发布于 2014-03-06 17:45:54

我试过了,但它总是返回整个对象。

此方法返回与给定规范匹配的单个实体。请查看here

根据我的理解,这是正确的方式。您可以正常访问实体的属性(例如,MyInfo.getIdProperty()

票数 1
EN

Stack Overflow用户

发布于 2019-11-07 06:38:21

规范是where子句的抽象。由于JPA标准API的设计,您可以在规范中使用所有类型的东西,但是除了声明where子句之外,任何副作用的行为都是未定义的。

如果您想要控制选择列表,您可以使用带有投影的查询派生和非常有限的查询支持,或者在自定义方法中构造完整的自定义查询。

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

https://stackoverflow.com/questions/22171822

复制
相关文章

相似问题

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