我正在使用以下代码检索我的数据
Criteria cr = session.createCriteria( JobProcess.class );
cr.createAlias("sendMarcs", "sm");
cr.addOrder( Order.desc( "processedTime") );
cr.addOrder( Order.asc( "sm.ats" ) );
它会返回所有数据,但所有数据都会多次显示,当它应该是一个大小为673
的列表时,会返回一个大小为99
的列表。我不知道为什么会这样。
是的,我看过hibernate正在使用的SQL,这是正确的。
此外,如果我删除别名及其顺序,则数据将按预期显示。没有倍增,但没有排序。
JobProcess.java
@Entity
@Table(name = "jobprocess")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
public class JobProcess {
@Id
@GeneratedValue
private Long id;
@Basic(optional = false)
@Column(length = 20, name="customerid")
private String customerId;
@Basic(optional=false)
@Column(length = 100)
private String ATS;
@Basic(optional=true)
@Temporal(TemporalType.TIMESTAMP)
@Column(name="timeprocessed")
private java.util.Date processedTime;
@Basic(optional=false)
@Column(length = 1)
private String state;
@Column(length = 300)
private String notes;
@Basic(optional = false)
private long nos;
@OneToMany(mappedBy = "jobprocessid")
private Set<SendMarc> sendMarcs = new HashSet<SendMarc>();
// getters and setters
}
SendMarc.java
@Entity
@Table( name = "sendmarc" )
@Cache( usage = CacheConcurrencyStrategy.READ_WRITE )
public class SendMarc
{
@Id
@GeneratedValue
private BigInteger id;
@Basic( optional = true )
private BigInteger marcfileid;
@Basic( optional = false )
private long jobprocessid;
@Basic( optional = false )
@Column( length = 50 )
private String ats;
// getters and setters
}
答案 0 :(得分:2)
它为每个检索到的行返回一个对象,因为没有distinct的HQL查询会这样做。有条件,你必须使用
cr.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY);
答案 1 :(得分:0)
#createAlias()
为其加入的关联创建别名。在您的情况下,如果没有它,您只需从JobProcess
表中检索没有连接的所有行,如果有其他连接,则会得到不同的结果。