1、Mybatis是什么?

Mybatis是一个封装了JDBC的ORM框架,只需要关注SQL语句的本身,不需要关注加载驱动、创建连接等,并且还支持动态SQL。

2、MyBatis的核心组件有哪些?

MyBatis的核心组件包括SqlSessionFactoryBuilder,SqlSessionFactory,SqlSession和Mapper。下边我们依次介绍。

SqlSessionFactoryBuilder是一个构建器,通过XML配置文件或者Java编码获得资源来构建SqlSessionFactory,通过Builder可以构建多个SessionFactory。其生命周期一般只存在于方法的局部,用完即可回收。一般通过如下语句建立:

1

SqlSessionFactory  factory  = SqlSessionFactoryBuilder.build(inputStream);

SqlSessionFactory的作用就是创建SqlSession,也就是创建一个会话。每次程序需要访问数据库,就需要使用到SqlSession。所以SqlSessionFactory应该在MyBatis应用的整个生命周期中。为了减少每次都创建一个会话带来的资源消耗,一般情况下都会使用单例模式来创建SqlSession。创建方式如下:

1

SqlSession sqlSession = SqlSessionFactory.openSession();

SqlSession就是一个会话相当于JDBC中的Connection对象,既可以发送SQL去执行并返回结果,也可以获取Mapper接口。SqlSession是一个线程不安全的对象,其生命周期应该是请求数据库处理事务的过程中。每次创建的SqlSession对象必须及时关闭,否则会使得数据库连接池的活动资源减少,影响系统性能。
 

Mapper也叫做映射器,由Java接口和XML文件(或者是注解)共同组成,给出了对应的SQL和映射规则,主要负责发送SQL去执行,并且返回结果。通过下边的语句来获取Mapper,接下来就可以调用Mapper中的各个方法去获取数据库结果了。

1

XXMapper xxMapper = sqlSession.getMapper(XXMapper.class); 

解析:

四大核心组件是MyBatis框架的重要组成部分,必须熟练掌握使用并且了解组件作用。

根据Demo展示,我们看到Test测试类中创建SqlSessionFactory的过程首先是通过读取xml配置,然后使用SqlSessionFactorybuilder来build一个SqlSessionFactory。具体创建过程的步骤如下:

  • 通过XMLConfigBuilder解析配置的XML文件,读出配置参数,封装到Configuration类中
  • 使用Configuration对象去创建SqlSessionFactory,SqlSessionFactory在MyBatis中是一个接口而不是一个类,所以提供了一个其默认实现类DefaultSqlSessionFactory

创建SqlSessionFactory的本质是一种Builder模式。Configuration的主要作用如下:

  • 读入配置文件
  • 初始化基础配置。包括全局配置,别名,类型处理器,环境数据库标识以及Mapper映射器等
  • 提供单例
  • 执行一些重要的对象方法和初始化配置信息

3、MyBatis的动态SQL有了解吗?

MyBatis动态SQL可以在XML映射文件内,以标签的形式编写动态SQL。动态SQL的执行原理是,根据表达式的值完成逻辑判断并动态拼接SQL语句。

对动态SQL的支持是MyBatis的一大优点。MyBatis提供了9种动态SQL标签:

  • if:单条件分支的判断语句
  • choose, when, otherwise:多条件的分支判断语句
  • foreach:列举条件,遍历集合,实现循环语句
  • trim,where,set:是一些辅助元素,可以对拼接的SQL进行处理
  • bind:进行模糊匹配查询的时候使用,提高数据库的可移植性

4、MyBatis的Mapper中的常见标签有哪些?

Mapper中常见的标签如下:

  • select | insert | updae | delete
  • resultMap | parameterMap | sql | include | selectKey
  • trim | where | set | foreach | if | choose | when | otherwise | bind

5、MyBatis的Dao接口的工作原理有了解吗?(了解)

Dao接口即Mapper接口。接口全限名+方法名拼接字符串作为key值,可唯一定位一个MapperStatement。接口的全限名,就是映射文件中的namespace的值。接口的方法名,就是映射文件中Mapper的Statement的id值。接口方法内的参数,就是传递给SQL的参数。

Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MapperStatement。在MyBatis中,每一个<select>、<insert>、<update>、<delete>标签,都会被解析为一个MapperStatement对象

例如:com.mapper.UserMapper.getUserInfo,可以唯一找到namespace为com.mapper.UserMapper下面 id 为 getUserInfo的 MapperStatement。

Mapper接口的工作原理是JDK动态代理,MyBatis运行时会使用JDK动态代理为Mapper接口生成代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement所代表的SQL,然后将SQL执行结果返回。

(1)Dao接口中的方法可以重载吗?(掌握)

当Dao接口中的方法参数不同时,可以构成重载吗?回答这个问题之前,我们可以先来温习下何为重载?

  • 重载是指一个类里面(包括父类的方法)存在方法名相同,但是参数不一样的方法,参数不一样可以是不同的参数个数、类型或顺序
  • 如果仅仅是修饰符、返回值、throw的异常不同,那么这是2个相同的方法

了解了映射器的工作原理之后,我们应该可以得出下边的结论:

Mapper接口里的方法,是不能重载的。 dao层中接口的方法名与xml中的标签id值是一致的,一旦出现方法重载之后就可会出现相同的方法名,xml中的id也是重名的了,一运行系统就会报错

(2)不同的映射文件xml中的id值可以重复吗?

前面我们说了,MyBatis使用全限名+方法名来寻找对应的MapperStatement,那么看起来我们是不可以定义相同的id值的。但是注意需要分情况讨论该问题。

  • 不同的xml映射文件,如果配置了namespace,那么id可以重复
  • 如果没有配置namespace,那么id不能重复

6、MyBatis中 # 和 $ 的区别是什么?(高频考点)

MyBatis面试知识

7、MyBatis的缓存机制有了解吗?

MyBatis面试知识

8、MyBatis的接口绑定是什么?有哪些实现方式?

接口绑定就是在MyBatis中任意定义接口,然后把接口里面的方法和SQL语句绑定, 我们直接调用接口方法就可以。

MyBatis面试知识

接口绑定有两种实现方式:

  • 通过注解绑定,就是在接口的方法上面加上 @Select、@Update等注解,里面包含SQL语句来绑定
  • 通过xml里面写SQL来绑定, 在这种情况下,要指定xml映射文件里面的namespace必须为接口的全路径名。

接口绑定方式的选择:

当SQL语句比较简单时候,用注解绑定;当SQL语句比较复杂时候,用xml绑定;实际的开发中,我们一般都使用xml绑定方式。

 

 

 

 

 

 

相关文章:

  • 2021-11-24
  • 2021-08-08
  • 2021-12-18
  • 2021-11-21
  • 2021-12-13
  • 2021-06-25
  • 2021-11-03
猜你喜欢
  • 2021-05-08
  • 2021-10-26
  • 2021-12-19
  • 2022-02-17
  • 2022-12-23
  • 2021-06-22
相关资源
相似解决方案