java框架 - MyBatis架构

  1. MyBatis编程步骤是什么样的?
    1、 创建SqlSessionFactory
    2、 通过SqlSessionFactory创建SqlSession
    3、 通过sqlsession执行数据库操作
    4、 调用session.commit()提交事务
    5、 调用session.close()关闭会话

  2. 请说说MyBatis的工作原理java框架 - MyBatis架构_第1张图片

在学习 MyBatis 程序之前,需要了解一下 MyBatis 工作原理,以便于理解程序。MyBatis 的工作
原理如下图

  1. 读取 MyBatis 配置文件:mybatis-config.xml 为 MyBatis 的全局配置文件,配置了 MyBatis 的运
    行环境等信息,例如数据库连接信息。
  2. 加载映射文件。映射文件即 SQL 映射文件,该文件中配置了操作数据库的 SQL 语句,需要在
    MyBatis 配置文件 mybatis-config.xml 中加载。mybatis-config.xml 文件可以加载多个映射文
    件,每个文件对应数据库中的一张表。
  3. 构造会话工厂:通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory。 4. 创建会话对象:由会话工厂创建 SqlSession 对象,该对象中包含了执行 SQL 语句的所有方法。
  4. Executor 执行器:MyBatis 底层定义了一个 Executor 接口来操作数据库,它将根据 SqlSession
    传递的参数动态地生成需要执行的 SQL 语句,同时负责查询缓存的维护。
  5. MappedStatement 对象:在 Executor 接口的执行方法中有一个 MappedStatement 类型的参
    数,该参数是对映射信息的封装,用于存储要映射的 SQL 语句的 id、参数等信息。
  6. 输入参数映射:输入参数类型可以是 Map、List 等集合类型,也可以是基本数据类型和 POJO 类
    型。输入参数映射过程类似于 JDBC 对 preparedStatement 对象设置参数的过程。
  7. 输出结果映射:输出结果类型可以是 Map、 List 等集合类型,也可以是基本数据类型和 POJO 类
    型。输出结果映射过程类似于 JDBC 对结果集的解析过程。
  8. MyBatis的功能架构是怎样的

我们把Mybatis的功能架构分为三层:
API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一
接收到调用请求就会调用数据处理层来完成具体的数据处理。
数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目
的是根据调用的请求完成一次数据库操作。
基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这
些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的
支撑。
11. MyBatis的框架架构设计是怎么样的
java框架 - MyBatis架构_第2张图片

这张图从上往下看。MyBatis的初始化,会从mybatis-config.xml配置文件,解析构造成
Configuration这个类,就是图中的红框。

  1. 加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加
    载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配
    置),存储在内存中。
  2. SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、
    JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根
    据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。
  3. SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。
  4. 结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者
    基本数据类型,并将最终结果返回。
  5. 什么是DBMS
    DBMS:数据库管理系统(database management system)是一种操纵和管理数据库的大型软件,
    用于建立、使用和维护数zd据库,简称dbms。它对数据库进行统一的管理和控制,以保证数据库
    的安全性和完整性。用户通过dbms访问数据库中的数据,数据库管理员也通过dbms进行数据库
    的维护工作。它可使多个应用程序和用户用不同的方法在同时版或不同时刻去建立,修改和询问数
    据库。DBMS提供数据定义语言DDL(Data Definition Language)与数据操作语言DML(Data
    Manipulation Language),供用户定义数据库的模式结构与权限约束,实现对数据的追加权、删
    除等操作。
  6. 为什么需要预编译
    定义:
    SQL 预编译指的是数据库驱动在发送 SQL 语句和参数给 DBMS 之前对 SQL 语句进行编译,
    这样 DBMS 执行 SQL 时,就不需要重新编译。
    为什么需要预编译
    JDBC 中使用对象 PreparedStatement 来抽象预编译语句,使用预编译。预编译阶段可以优
    化 SQL 的执行。预编译之后的 SQL 多数情况下可以直接执行,DBMS 不需要再次编译,越
    复杂的SQL,编译的复杂度将越大,预编译阶段可以合并多次操作为一个操作。同时预编译
    语句对象可以重复利用。把一个 SQL 预编译后产生的 PreparedStatement 对象缓存下来,
    下次对于同一个SQL,可以直接使用这个缓存的 PreparedState 对象。Mybatis默认情况下,
    将对所有的 SQL 进行预编译。
    还有一个重要的原因,复制SQL注入
  7. Mybatis都有哪些Executor执行器?它们之间的区别是什么?
    Mybatis有三种基本的Executor执行器,SimpleExecutor、ReuseExecutor、BatchExecutor。
    SimpleExecutor:每执行一次update或select,就开启一个Statement对象,用完立刻关闭
    Statement对象。
    ReuseExecutor:执行update或select,以sql作为key查找Statement对象,存在就使用,不存
    在就创建,用完后,不关闭Statement对象,而是放置于Map内,供下一次
    使用。简言之,就是重复使用Statement对象。
    BatchExecutor:执行update(没有select,JDBC批处理不支持select),将所有sql都添加到批
    处理中(addBatch()),等待统一执行(executeBatch()),它缓存了多个Statement对象,每个
    Statement对象都是addBatch()完毕后,等待逐一执行executeBatch()批处理。与JDBC批处理相
    同。
    作用范围:Executor的这些特点,都严格限制在SqlSession生命周期范围内。
  8. Mybatis中如何指定使用哪一种Executor执行器?
    在Mybatis配置文件中,在设置(settings)可以指定默认的ExecutorType执行器类型,也可以手
    动给DefaultSqlSessionFactory的创建SqlSession的方法传递ExecutorType类型参数,如
    SqlSession openSession(ExecutorType execType)。
    配置默认的执行器。SIMPLE 就是普通的执行器;REUSE 执行器会重用预处理语句(prepared
    statements); BATCH 执行器将重用语句并执行批量更新。
  9. Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?
    Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是
    一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载
    lazyLoadingEnabled=true|false。
    它的原理是,使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调
    用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好
    的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完
    成a.getB().getName()方法的调用。这就是延迟加载的基本原理。
    当然了,不光是Mybatis,几乎所有的包括Hibernate,支持延迟加载的原理都是一样的。

你可能感兴趣的:(java面经,java,面试)