如何在Criteria API(JPA)中获取单个列的不同值

时间:2017-10-07 13:20:04

标签: java hibernate jpa jpa-criteria

嗨,我是JPA&的新手。 Criteria API。 我正在尝试获取单个列的不同值(尝试仅获取TestId的不同值)。我的数据库中有下表。

__________________________________
|TestId(Pk) | TestCol(PK) | TestEx|
__________________________________

我有以下课程 模型类

@Data
@Entity
@Table(schema = "TEST", name = "TEST_TYPE")
public class Test {
    @EmbeddedId
    private TestPK id;

    @Column(nmae = "TestEX")
    private double testEx
}

@Data
@Embeddable
public class TestPK {
    @Column(name = "TestId")
    private String testId;

    @Column(name="TestCol")
    private String testcol
}

存储库类

public class TestRepoImpl {

    @PersistenceContext
    EntityManager em;

    @Override
    public List<Test> getData() {
        CriteriaBuilder cb = em.getCriteriaBuilder();
        CriteriaQuery<Test> cq = cb.createQuery(Test.class);
        Root<Test> root = cq.from(Test.class);

        // cq.get(Test_.id).get(TestPK_.testId);
        // cq.select(root);
        cq.multiselect(root.get(Test_.id).get(TestPK_.testId));
        cq.distinct(true);
        // List<Tuple> ts = em.createQuery(cq).getResultList();
        List<Test> data = em.createQuery(cq).getResultList();
        return data;
    }
} 

我收到以下错误。

不允许部分对象查询维护缓存或进行编辑。 你必须使用dontMaintainCache()。

2 个答案:

答案 0 :(得分:1)

请尝试 here ((org.eclipse.persistence.jpa.JpaQuery)query).getDatabaseQuery().dontMaintainCache();

中提到的此选项

答案 1 :(得分:0)

结果不是Test的列表,而是Stringprivate String testId;

更改

  

CriteriaQuery<Test> cq = cb.createQuery(Test.class);

  

CriteriaQuery<String> cq = cb.createQuery(String.class);

其余的代码可能会有所帮助。