读书人

IBATIS的思维不同的实现思路

发布时间: 2012-06-28 15:20:03 作者: rapoo

IBATIS的思想,不同的实现思路

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#

?

读书人网 >开源软件

热点推荐