我按照这个例子:https://code.google.com/p/mybatis/wiki/ResultHandlerExample https://code.google.com/p/mybatis/wiki/ResultHandlerExample这是我的界面:
public interface CountryDirRdbMapper {
public static class CountryDirBaseItemWithText {
public CountryDirBaseItem baseItem;
}
public List<CountryDirBaseItem> select(ResultHandler handler);
}
这是我的 xml 映射器
<resultMap id="readItemsRM" type="CountryDirRdbMapper$CountryDirBaseItemWithText">
<association property="baseItem" javaType="CountryDirBaseItem">
<id property="id" column="Id"/>
<result property="comment" column="Comment"/>
</association>
</resultMap>
这段代码构成了我的 DAO:
SqlSession session = MyBatisConnectionFactory.getSqlSessionFactory().openSession(true);
List<CountryDirBaseItem> list;
try{
CountryDirRdbMapper mapper = session.getMapper(CountryDirRdbMapper.class);
class MyResultHandler implements ResultHandler {
@Override
public void handleResult(ResultContext context) {
System.out.println("#########################");
}
}
MyResultHandler handler=new MyResultHandler();
list= mapper.select(handler);
}
finally {
session.close();
}
然而,结果处理程序永远不会被调用。在这个例子中,我跟随人们说有同样的问题。那么如何让它发挥作用呢?或者 mybatis 3 不支持结果处理程序?
我找到了答案。不幸的是 MyBatis 开发人员根本不关心用户。他们真丢人。事实是,当我们使用自定义结果处理程序时,我们必须使用会话而不是接口。
MyResultHandler handler=new MyResultHandler();
session.select("select", handler);
之后,必须从处理程序中获取结果。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)