java中使用dao类获取行的异常

时间:2015-04-30 13:03:05

标签: java hibernate

我的DAO课程:

@SuppressWarnings("unchecked")
public int getRowCount(Map<String, Object> searchParam) throws DAOReadException {
    List<Client> clientRow = null;
    try {
        Criteria criteria = Criteria.forClass(Client.class);
        //set criteria search
        for (String key : searchParam.keySet()) {

            /*if(key.equals("ClientPK.clientId1")){
                criteria.add(Restrictions.like("ClientPK.clientId", searchParam.get(key)));
            }*/
            if(key.equals("clientPK.clientId")){
                criteria.add(Restrictions.eq(key, Integer.parseInt(searchParam.get(key).toString())));
            }
            if(key.equals("clientName")){
                criteria.add(Restrictions.like(key, searchParam.get(key)));
            }

            if(key.equals("status")){
                criteria.add(Restrictions.eq(key, Short.parseShort(searchParam.get(key).toString())));
            }


            //Bug# 12544 start
            if(key.equals("orgId"))
            {
                criteria.add(Restrictions.eq("ClientPK.orgId", searchParam.get(key)));
            }
            //Bug# 12544 End
    }
        criteria.addOrder(Order.desc("createdDate"));
        clientRow = (List<Client>) findByCriteria(criteria);
    }

    catch (Exception e) {
        throw new DAOReadException(e);
    }
    int rowCount = 0;
    if (clientRow != null) {
        rowCount = clientRow.size();
    }

    return rowCount;
}

}

错误是:

  

java.lang.IllegalArgumentException:org.hibernate.QueryException:无法解析属性:ClientPK:com.vin.eretail.model.client.Client [从com.vin.eretail.model.client.Client中选择此项为这个this.ClientPK.orgId =?按此命令.createdDate desc]

1 个答案:

答案 0 :(得分:1)

似乎改变如下:

    //Bug# 12544 start
    if(key.equals("orgId"))
    {
       criteria.add(Restrictions.eq("clientPK.orgId", searchParam.get(key)));
     }
        //Bug# 12544 End

仍然需要查看您的客户端类