MyBatis – 不调用ResultHandler

我按照这个示例: https : //code.google.com/p/mybatis/wiki/ResultHandlerExample这是我的界面:

public interface CountryDirRdbMapper { public static class CountryDirBaseItemWithText { public CountryDirBaseItem baseItem; } public List select(ResultHandler handler); } 

这是我的xml映射器

        

这段代码形成了我的DAO:

 SqlSession session = MyBatisConnectionFactory.getSqlSessionFactory().openSession(true); List 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); 

之后,结果必须从处理程序中获取。

从各条信息中找出来

  1. 你需要从你的设置中获取SqlSession的实例

    sqlSession = sqlSessionFactory.openSession();

  2. 要将mapper与结果处理程序一起使用,您需要使映射器返回void(重要)并为此映射器设置结果类型(重要)

    @Select(“select * from user”)void selectAllUser(ResultHandler handler)

  3. 从你的sqlSession获取mapper

    UserMapper mapper = sqlSession.getMapper(User.class);

  4. 使用handler设置会话方法,第一个参数是要与处理程序关联的映射器的方法名称

    sqlSession.select(“selectAllUser”,yourResultHandler);

  5. 开始使用你的映射器

    mapper.selectAllUser(yourResultHandler);

  6. 完成后不要忘记释放(关闭)会话