MyBatis中可以通过使用延迟加载来解决性能问题,延迟加载是指在需要使用某个对象时才会去查询数据库获取该对象的信息。在MyBatis中有两种方式可以实现延迟加载:
<resultMap id="userMap" type="User">
<id property="id" column="id"/>
<result property="name" column="name"/>
<collection property="articles" ofType="Article" column="user_id" select="selectArticles" fetchType="lazy"/>
</resultMap>
User user = sqlSession.selectOne("selectUser", 1);
LazyLoader lazyLoader = new LazyLoader() {
@Override
public void load() {
user.setArticles(sqlSession.selectList("selectArticles", user.getId()));
}
};
user.setLazyLoader(lazyLoader);
通过使用懒加载和延迟加载器,可以在需要时才去查询关联对象的信息,从而提高查询性能。