Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 选择特定列的Spring数据JPA规范_Java_Spring_Jpa_Spring Data_Spring Data Jpa - Fatal编程技术网

Java 选择特定列的Spring数据JPA规范

Java 选择特定列的Spring数据JPA规范,java,spring,jpa,spring-data,spring-data-jpa,Java,Spring,Jpa,Spring Data,Spring Data Jpa,我们可以通过在存储库界面中编写自定义@Query方法来选择特定列。但是,我不想为不同的属性编写这么多方法 我尝试了这个,但它始终返回整个对象 public class MySpecifications { public static Specification<MyInfo> propertiesWithId(final String[] properties, final Object id, final String idProperty) {

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

我尝试了这个,但它始终返回整个对象

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

        };
    }
}
这是正确的方法吗?错在哪里

我尝试了这个,但它始终返回整个对象

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

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


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

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


规范是where子句的抽象。由于JPA标准API的设计,您可以在规范中添加各种内容,但除了声明where子句外,任何副作用的行为都是未定义的


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

是否考虑过使用投影?