今天看了一篇有关Mybatis非常好的文章,顺便写了一下学习心得。

原文地址:https://blog.csdn.net/u010349169/article/details/40422941

一。Mybatis的框架设计

Mybatis框架大致可以分为四个部分:

(1)接口层:用于实现和数据库的交互 ---- 可以通过两种方式来调用:Mapper接口绑定  或   Mapper.xml配置(基于StatementID,即<mapper标签中的>namespace值 + sql标签中的id值)

(2)数据处理层:Mybatis的核心  主要

              a.动态SQL的创建  ---  一个语句(一个<select>/<delete>等标签对对应一个Statement对象)

              b.SQL语句执行

              c.封装查询结果集为List<E>

(3)框架支持层:a.事务管理机制  ---  如JDBC原生事务管理的commit(),rollback(),close()   ---  用SqlSession对象执行

        b.数据库连接池管理机制  ---  如<dataSource>标签中的type='POOLED'即为使用数据库连接池   ---  多个数据库连接对象(即Connection对象),已被占用的状态为(active),未被占用的为(idle)

        c.缓存机制  ---  为减小服务器和数据库的压力和提升效率  --- 如SqlSession(一级缓存)、SqlSessionFactory(二级缓存)  ----  每一个Statement对象有一个自己对应的缓存

        d.SQL语句的配置  ---  Mapper.xml文件配置  和  注解配置(通过注解传入参数 @param Object obj)

(4)引导层:引导层是配置和启动Mybatis配置信息的方式。我使用的是mybatis.xml配置方式

二。Mybatis的一些核心组件

该图来源于原博客:https://blog.csdn.net/u010349169/article/details/40422941

博主主页:http://blog.csdn.net/luanlouis/

Mybatis初始化加载时-->Configuration-->根据Mybatis.xml和Mapper.xml配置文件创建一个或多个MappedStatement对象-->

将每个对象以key-value的形式存储到Configuration的一个Map中,其中key为(Statement ID)也就是namespace+id,value为对应的MappedStatement对象

    可通过SqlSession.getConfiguration()获得Configuration对象

创建SqlSession-->根据Statement ID获得Configuration中对应的MappedStatement对象-->Executor根据SqlSession传递的参数执行query()方法-->创建StatementHandler,并让该对象根据参数执行数据库相关操作,获得返回结果

Executor的作用:(1)根据传递的参数,通过生成BoundSql对象,完成SQL语句的动态解析,以便StatementHandler使用

        (2)为查询创建缓存,以提高性能。(这里应该是每次查询,先看是否有相应缓存,没有缓存再去数据库中执行sql语句查找

        (3)创建JDBC的Statement连接对象,传递给StatementHandler对象,返回List查询结果

StatementHandler对象主要工作:

        (1)对于JDBC的PreparedStatement对象,会对其占位符?进行设置。(通过ParameterHandler对象)

        (2)通过List<E> query(Statement statement, ResultSetHandler resultSetHandler)方法执行Statement,并将返回结果resultSet封装成List

Mybatis的原理相关的更多相关文章

  1. Mybatis插件原理分析(二)

    在上一篇中Mybatis插件原理分析(一)中我们主要介绍了一下Mybatis插件相关的几个类的源码,并对源码进行了一些解释,接下来我们通过一个简单的插件实现来对Mybatis插件的运行流程进行分析. ...

  2. 【转】MaBatis学习---源码分析MyBatis缓存原理

    [原文]https://www.toutiao.com/i6594029178964673027/ 源码分析MyBatis缓存原理 1.简介 在 Web 应用中,缓存是必不可少的组件.通常我们都会用 ...

  3. 深入理解MyBatis的原理:整个体系

    前言:工作中虽然用到了 MyBatis,可完全不知道为什么,再不学习就晚了,这里将记录我的学习笔记,整个 MyBatis 的体系. 一.简介 1.传统的JDBC JDBC 是一种典型的桥接模式. 使用 ...

  4. Mybatis架构原理(二)-二级缓存源码剖析

    Mybatis架构原理(二)-二级缓存源码剖析 二级缓存构建在一级缓存之上,在收到查询请求时,Mybatis首先会查询二级缓存,若二级缓存没有命中,再去查询一级缓存,一级缓存没有,在查询数据库; 二级 ...

  5. MyBatis工作原理

    Mybatis工作原理: 我们的应用程序通过mybatis提供的api,增删改查方法来访问数据库,api底层调用了jdbc ,只不过mybatis对jdbc的封装是不完全封装,里面的sql语句需要我们 ...

  6. Mybatis的原理与JVM内存结构(面试题)

    Mybatis的原理 1.Mapper 接口在初始SQL SessionFactory注册的 2.Mapper 接口注册在名为MapperRegistry类的 HasMap中 key=Mapper c ...

  7. 面试官:你分析过mybatis工作原理吗?

    Mybatis工作原理也是面试的一大考点,必须要对其非常清晰,这样才能怼回去.本文建立在Spring+SpringMVC+Mybatis整合的项目之上. 我将其工作原理分为六个部分: 读取核心配置文件 ...

  8. mybatis运行原理

    mybatis运行原理 运行过程中涉及到的类或者接口 Resources(c) :用于加载mybatis核心配置文件 XMLConfigBuilder(c) :用于解析xml文件(核心配置文件) Co ...

  9. spring boot 整合 mybatis 以及原理

    同上一篇文章一样,spring boot 整合 mybatis过程中没有看见SqlSessionFactory,sqlsession(sqlsessionTemplate),就连在spring框架整合 ...

随机推荐

  1. 检测MySQL主从备份是否运行

    通过查看 slave  状态,确保 Slave_IO_Running: Yes Slave_SQL_Running: Yes #!/bin/bash#Author:Darius-Dmysql -uro ...

  2. python_flask 基础巩固 (URL传输传递方式)

    URL传输传递@app.route('/'):@app.route('/list/')@app.route('/list/<int:id>/')@app.route('/list/< ...

  3. Borg, Omega, and Kubernetes读后笔记

    前言 最近又读了一遍 Borg, Omega, and Kubernetes 这篇文章,觉得这个文章写得很好,让我对架构设计有了进一步的认识,所以想写一篇读后笔记. 原文地址,还有篇中文翻译的,这个中 ...

  4. Py福利,基于uiautomatorviewer 的Python 自动化代码自动生成工具分享(jar已发布GitHub,欢迎Star)

    前言做UI自动化无论你用SDK自带的uiautomatorviewer还是Macaca还是Appium自动的inspector,代码最多的就是那些繁琐重复的找元素后点击,输入,长按.....等.现在偷 ...

  5. EF学习笔记(八):更新关联数据

    学习笔记主目录链接:ASP.NET MVC5 及 EF6 学习笔记 - (目录整理) 上一篇链接:EF学习笔记(七):读取关联数据 本篇原文链接:Updating Related Data 本篇主要考 ...

  6. Mybatis的JDBC提交设置/关闭mysql自动提交------关于mysql自动提交引发的惨剧

    学习Mybatis时提到了JDBC方式需要自己手动提交事务,如果不加session.commit会导致数据库的数据无法正常插入(程序本身又不给你报错,还装出一副我已经插入成功的样子) SqlSessi ...

  7. Linux时间戳转换成BCD码(转载)

    #include <stdio.h> #include <stdlib.h> #include <time.h> #include <math.h> / ...

  8. MySQL下创建数据库以及授权用户

    一.新建数据库 1.首先登录MySQL:(输入 mysql -u root -p 命令,然后输入密码按回车即可) 2.在mysql> 下输入如下命令,回车,即可创建数据库 (test为数据库名) ...

  9. 网易彩票-我的彩票-设置-cell跳转界面

    1. 点击“cell”推出对应的界面 1.1 新建group,名为:Setting 路径:MYLottery(我的彩票)->Controller 1.2 新建Cocoa Touch Class, ...

  10. 背水一战 Windows 10 (98) - 关联启动: 使用外部程序打开一个文件, 使用外部程序打开一个 Uri

    [源码下载] 背水一战 Windows 10 (98) - 关联启动: 使用外部程序打开一个文件, 使用外部程序打开一个 Uri 作者:webabcd 介绍背水一战 Windows 10 之 关联启动 ...