我有一個3列作爲主鍵的表。碼和映射如下:複合PK字段的分離標準?
類爲複合鍵
public class CIDResultCurrentState implements Serializable
{
private static final long serialVersionUID = -4346801004559840730L;
private String mID = "";
private String sNo = "";
private String date = "";
// getters, setters, equals(), hashCode() omitted for brevity
}
類爲表
public class ResultCurrentState implements IBaseModel, Serializable
{
private static final long serialVersionUID = 5707101766665188676L;
private CIDResultCurrentState ID;
private byte[] rData;
private byte[] pData;
// getters, setters, equals(), hashCode() omitted for brevity
}
休眠XML映射
<hibernate-mapping>
<class name="org.irvas.amrregina.backend.model.ResultCurrentState" table="RESULT_CURRENT_STATE">
<composite-id name="ID" class="org.irvas.amrregina.backend.model.CIDResultCurrentState">
<key-property name="mID" column="M_ID" type="java.lang.String"/>
<key-property name="sNo" column="S_NO" type="java.lang.String"/>
<key-property name="date" column="S_DATE" type="java.lang.String"/>
</composite-id>
<property name="rData" column="R_DATA" not-null="false" type="binary"/>
<property name="pData" column="P_DATA" not-null="false" type="binary"/>
</class>
</hibernate-mapping>
所有這些工作正常。現在,我需要編寫DetachedCriteria查詢來獲取特定的ResultCurrentState對象/記錄。我想是這樣的,但它不工作(我不知道該不該把這個複合ID爲嵌套財產與否):
//...
DetachedCriteria criteria = DetachedCriteria.forClass(ResultCurrentState.class);
DetachedCriteria criteriaID = criteria.createCriteria("ID");
criteriaID.add(Restrictions.eq("mID", arg.getType().getMID()));
criteriaID.add(Restrictions.eq("sNo", arg.getSN()));
criteriaID.add(Restrictions.eq("date", date));
return (ResultCurrentState)DataAccessUtils.uniqueResult(getHibernateTemplate().findByCriteria(criteriaID));
如果有人可以幫我寫正確的標準,我真的很感激它。
謝謝。
不,不工作,要麼...此外,正如我已經說過,我需要的DetachedCriteria,因爲我使用Spring的HibernateTemplate的工作,我根本不使用Session或Criteria。 – Less
你解決了這個問題嗎? – Maxrunner