工作中遇到的一个关于hibernate jpa的问题
昨天用hibernate-jpa(2.0)时发现一个问题,刚开始以为是查询sql和自己代码的bug。
经反复调试,发现用hql native query不使用join的sql无异常。
使用join的sql如果同时取a,b两张表的id,会导致取出的值完全相同。
例如:
select a.id,b.id from tablea a ,tableb b where a.id=b.aid?
查询出来的a.id和b.id的值是完全相同的(mysql里是肯定不一样的)。
但同样的hql使用createquery构造Query就一点问题没有,很是奇怪。
具体原因待查,特此记录下来,欢迎大家共同探讨。
另外,用createquery构造query时,hql中使用limit限制结果集大小是无效的。
需使用:
query.setFirstResult((pageNum-1)*pageSize);
query.setMaxResults(pageSize);
来限制结果集大小。