gpt4 book ai didi

java - 复合 PK 字段的分离标准?

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:00:39 26 4
gpt4 key购买 nike

我有一个包含 3 列作为主键的表。代码及映射如下:

复合键的类

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
}

hibernate 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 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 用作前缀,因为您已在类 ResultCurrentState 中使用该名称在 POJO 中声明了复合键:

private CIDResultCurrentState ID;

至于查询执行,我认为它是这样的(我的不同——不一定更好):

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

使用我的看起来像这样:

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

关于java - 复合 PK 字段的分离标准?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7332774/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com