温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

浅谈Mybatis原始执行方式Executor

发布时间:2020-07-16 15:28:04 来源:亿速云 阅读:139 作者:小猪 栏目:开发技术

小编这次要给大家分享的是浅谈Mybatis原始执行方式Executor,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。

一、通过SqlSessionFactory创建sqlsession,再由Sqlsession获取session对象,然后通过session中的执行器Executor,去执行MapperStatement封装的sql语句

@Test
public void findAll() throws IOException {
  //1.读取配置文件
  InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
  //2.创建 SqlSessionFactory 的构建者对象
  SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
  //3.使用构建者创建工厂对象 SqlSessionFactory
  SqlSessionFactory factory = builder.build(in);
  //4.使用 SqlSessionFactory 生产 SqlSession 对象
  SqlSession session = factory.openSession();

  List<User> users = session.selectList("findAll");
   /*
    //5.使用 SqlSession 创建 dao 接口的代理对象(接口绑定原理使用的jdk动态代理)
    UserDao userDao = session.getMapper(UserDao.class);
    //6.使用代理对象执行查询所有方法
    List<User> users = userDao.findAll();
   */
  for (User user : users) {
    System.out.println(user);
  }
  //7.释放资源
  session.close();
  in.close();
}

二、执行器Executor的分类

  •  SimpleExecutor:默认的Executor,每个SQL执行时都会创建新的 Statement,继承了
  • BaseExecutor
  • CachingExecutor:可缓存数据的Executor,用于二级缓存的执行器
  • BatchExecutor:用于批处理的Executor
  • ReuseExecutor:相同的SQL会服用的Statemen

看完这篇关于浅谈Mybatis原始执行方式Executor的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI