2011-09-07 56 views
3

我有一個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)); 

如果有人可以幫我寫正確的標準,我真的很感激它。
謝謝。

回答

1
Criteria criteria = session.forClass(ResultCurrentState.class); 
DetachedCriteria criteriaID = DetachedCriteria.forClass(CIDResultCurrentState.class); 
criteriaID.add(Restrictions.eq("mID", arg.getType().getMID())); 
criteriaID.add(Restrictions.eq("sNo", arg.getSN())); 
criteriaID.add(Restrictions.eq("date", date)); 
criteria.add(Subqueries.propertyIn("ID", criteriaID)); 
return criteria.list(); 
+0

不,不工作,要麼...此外,正如我已經說過,我需要的DetachedCriteria,因爲我使用Spring的HibernateTemplate的工作,我根本不使用Session或Criteria。 – Less

+0

你解決了這個問題嗎? – Maxrunner

1

至於使用複合主鍵,這應該是足夠的條件:

DetachedCriteria criteria = DetachedCriteria.forClass(ResultCurrentState.class); 
criteria.add(Restrictions.eq("ID.mID", arg.getType().getMID())); 
criteria.add(Restrictions.eq("ID.sNo", arg.getSN())); 
criteria.add(Restrictions.eq("ID.date", date)); 

注意ID作爲前綴,因爲你已經使用這個名稱聲明在POJO組合鍵,在類ResultCurrentState

private CIDResultCurrentState ID; 

至於查詢執行,我認爲它會這樣(我的是不同的 - 不一定好):

return (ResultCurrentState)DataAccessUtils.uniqueResult(getHibernateTemplate().findByCriteria(criteria)); 

使用我的將是這樣的:

List<ResultCurrentState> result = DataAccessUtils.find(criteria); 
+0

你解決了這個問題嗎? – ejuan