ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

MyBatis执行器

2021-06-01 22:04:38  阅读:158  来源: 互联网

标签:执行器 SimpleExecutor ms MyBatis new Configuration RowBounds


Mybatis的执行器

下面先展示一张图,用来说明一下Mybatis执行器的整体架构

SimpleExecutor

首先SimpleExecutor是我们最常使用的一个执行器,无论我们执行什么方法默认调用的都是SimpleExecutor
下面是基本使用,这里可能会比较懵了,哪里来的configuration,doQuery,RowBounds,ResultHandler,BoundSql
在这里我来一一解释

SimpleExecutor simpleExecutor = new SimpleExecutor(configuration, transaction);
        MappedStatement ms = configuration.getMappedStatement("com.guan.ibatis.mapper.UserMapper.queryUsersInfo");
        BoundSql boundSql = ms.getBoundSql(null);
        List<User> users = simpleExecutor.doQuery(ms, null,
                RowBounds.DEFAULT, SimpleExecutor.NO_RESULT_HANDLER, boundSql);
        users.forEach(System.out::println);
  1. configuration我们读取配置文件使用SqlSessionFactoryBuilder来构建,而配置文件(Mybatis-config.xml)解析后就会将解析完的所有数据放到一个名为Configuration的类里面,我们的一些操作,比如设置Setting,设置数据源,设置映射文件,都可以通过new Configuration()来进行配置,而获取Configuration的实力,只需要我们SqlSessionFactoryBuilder.build()所创建的SqlSessionFactory就可以获取Configuration了--->SqlSessionFactory.getConfiguration()
  2. doQuery是BaseMapper的一个抽象方法,分别由三个子类进行实现,是最基本的查询方法,无论调用什么查询方法都会调用doQuery这个方法
  3. RowBounds分页条件,我们可以new RowBounds()来自定义分页条件,而RowBounds.DEFAULT就是new一个0-Integer.MAX_VALUE的RowBounds
  4. ResultHandler结果处理器
  5. BoundSql我们编写的sql语句,获取方法:ms.getBoundSql()没有参数就可以传null
  6. ms就是MappedStatement获取我们对应方法的属性,参数为statementid(包名.类名.方法名)

标签:执行器,SimpleExecutor,ms,MyBatis,new,Configuration,RowBounds
来源: https://www.cnblogs.com/GuanStudy/p/14839035.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有