这是我的发件人实体
@Entity
public class Sender {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long senderId;
...
...
public long getSenderId() {
return senderId;
}
public void setSenderId(long senderId) {
this.senderId = senderId;
}
}
当我尝试执行以下查询时:
StringBuilder query = new StringBuilder();
query.append("Select sender.* ");
query.append("From sender ");
query.append("INNER JOIN coupledsender_subscriber ");
query.append("ON coupledsender_subscriber.Sender_senderId = sender.SenderId ");
query.append("WHERE coupledsender_subscriber.Subscriber_subscriberId = ? ");
SQLQuery q = (SQLQuery) sessionFactory.getCurrentSession().createSQLQuery(query.toString());
q.setResultTransformer(Transformers.aliasToBean(Sender.class));
q.setLong(0, subscriberId);
return q.list();
出现以下错误:
错误:org.hibernate.property.BasicPropertyAccessor - HHH000123:类中的 IllegalArgumentException:be.gimme.persistence.entities.Sender,属性的设置方法:senderId
错误:org.hibernate.property.BasicPropertyAccessor - HHH000091:预期类型:long,实际值:java.math.BigInteger
发生这种情况是因为 Sender 类中的 senderId 实际上是 long 而不是 BigInteger(由 Hibernate 返回)。
我想知道在这种情况下最好的做法是什么,我应该使用 BigIntegers 作为 id(似乎有点矫枉过正)?
我应该手动将查询结果转换为 Sender 类的对象吗(那会很可惜)?或者我可以让 Hibernate 返回long
id 而不是BigInteger
s?还是有其他想法?
我正在使用 Spring、Hibernate 4.1.1 和 MySQL