我觉得这是一个愚蠢的问题,但我找不到答案。我有一个课程如下:
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
@Entity
@Table(name="DEMO_VARIABLES")
public class Variable implements Serializable
{
private static final long serialVersionUID = -1734898766626582592L;
@Id
@SequenceGenerator(name="VARIABLE_ID_GENERATOR", sequenceName="DEMO_VARIABLE_ID_SEQ", allocationSize=1)
@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="VARIABLE_ID_GENERATOR")
@Column(name="VARIABLE_ID", unique=true, nullable=false, precision=22)
private long variableId;
@Column(name="VARIABLE_NAME", nullable=false, length=50)
private String variableName;
@Column(name="VARIABLE_VALUE", nullable=false, length=500)
private String variableValue;
public Variable()
{
}
public long getVariableId()
{
return variableId;
}
public void setVariableId(long variableId)
{
this.variableId = variableId;
}
public String getVariableName()
{
return variableName;
}
public void setVariableName(String variableName)
{
this.variableName = variableName;
}
public String getVariableValue()
{
return variableValue;
}
public void setVariableValue(String variableValue)
{
this.variableValue = variableValue;
}
}
现在我想使用条件查询来加载整个表(即“select * from variables”)。我想更多地使用条件查询来实现代码一致性。我得到了这个例外:
java.lang.IllegalStateException: No criteria query roots were specified
at org.hibernate.ejb.criteria.CriteriaQueryImpl.validate(CriteriaQueryImpl.java:303)
at org.hibernate.ejb.criteria.CriteriaQueryCompiler.compile(CriteriaQueryCompiler.java:145)
at org.hibernate.ejb.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:437
我使用的查询是:
public List<Variable> loadAllVariables()
{
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Variable> query = builder.createQuery(Variable.class);
return em.createQuery(query).getResultList();
}
我知道异常意味着它想要这个:
Root<Variable> variableRoot = query.from(Variable.class);
但是如果没有Predicate,我看不到如何将Root对象放入查询中?
答案 0 :(得分:23)
我不确定,我是否理解正确,但如果目标是选择所有变量实体的获取列表,那么可以采用以下方法:
public List<Variable> loadAllVariables() {
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Variable> query = builder.createQuery(Variable.class);
Root<Variable> variableRoot = query.from(Variable.class);
query.select(variableRoot);
return em.createQuery(query).getResultList();
}
区别在于使用 select 。所有实现都不隐式使用from的最后一次调用来代替select。在JPA 2.0规范中,这被告知如下:
便携式应用程序应使用select或multiselect方法 指定查询的选择列表。不使用的应用程序 这些方法不可移植。
答案 1 :(得分:5)
使用查询及其根目录非常简单:
首先按照你描述的方式获得根:
Root<Variable> variableRoot = query.from(Variable.class);
之后,你必须告诉查询它应该对root做什么:在这种情况下选择。
query.select(variableRoot);
之后,您可以使用query.where(...)
函数等进一步修改查询。
完成后,您就可以使用
return em.createQuery(query).getResultList();
中的更多信息