Hibernate比较适合对数据进行增,删,改的操作,而iBatis适合进行数据 查询,批量操作,而且方便利用DB底层的功能;IBATIS最吸引人的地方应该是将SQL从JAVA代码中分离,便于维护;但IBATIS的语法和分页并不灵活。
这里有个新的实现思路:利用JAVA动态编译功能将拼SQL的JAVA代码配置到XML中,实现SQL和JAVA代码的分离;
另外IBATIS的分页是使用逻辑分页,在数据量大时,会出现内存溢出的问题,这里可以使用org.hibernate.dialect.Dialect 中的分页sql生成函数:
public String getLimitString(String query, int offset, int limit)
{
return getLimitString(query, offset > 0 || forceLimitUsage());
}
protected String getLimitString(String query, boolean hasOffset)
{
throw new UnsupportedOperationException("paged queries not supported");
}
oracle分页
SELECT T_2.* FROM (SELECT T_1.*, ROWNUM ROWSEQ FROM (
select * from HUST_ABORAD_ACHIEVEMENTS
) T_1 where rownum< #rowsEnd# + ") T_2 WHERE T_2.ROWSEQ >= #rowsStart#
mysql分页:
select * from A limit #startRow#, #endRow#
本文探讨了Hibernate与iBatis两种持久层框架的特点及适用场景。Hibernate适用于增删改操作,而iBatis更适合查询与批量操作,并详细介绍了如何通过Java动态编译功能实现SQL与Java代码的分离,以及在不同数据库中实现分页的方法。
738

被折叠的 条评论
为什么被折叠?



