美文网首页
Mybatis框架

Mybatis框架

作者: JumpBorderLine | 来源:发表于2019-08-14 11:33 被阅读0次

Mybatis是一个封装了JDBC的半自动化框架【自动:自动将结果封装为对象;非自动:SQL语句需要开发人员手写完成】,解决了我们使用JDBC时的繁琐操作问题,简化了代码,使开发人员只需去关注sql本身,大大提高了开发效率。Mybatis使用简单的XML或注解来配置和映射原生信息,将接口和POJO映射成数据库中的记录。

为了能深入理解mybatis,我们首先来认识下下面的几个东西和概念。

Mybatis的作用:持久层框架,用来实现用户与数据库交互的。

1、JDBC

JDBC(Java DataBase Connection)Java数据库连接,在实际开发中我们并非是直接对数据库进行操作,而是使用Java语言去操纵数据库,JDBC就起到了这个访问数据库的作用。

1.1 JDBC访问数据库

JDBC访问数据库一共6步,每一次都需要创建连接,使用后必须关闭。

1-注册驱动

2-创建连接

3-获取传输器(preparedStatement防SQL注入攻击)

4-执行SQL语句

5-处理结果

6-关闭连接,释放资源

2、ORM

ORM(Object Relation Mapping)对象关系映射,ORM是Mybatis的核心思想,用于持久化数据和实体对象关系的映射。采用XML配置SQL,灵活配置多种映射关系。

3、数据库连接池

传统方式使用JDBC操纵数据库,当需要连接时就向数据库要一个连接对象执行数据库操作,执行完成后关闭连接,将连接对象还给数据库。其中创建和销毁连接这两个过程非常耗费资源,效率低下,且连接未得到复用。

数据库连接池则是在程序刚启动时,就创建了一批连接对象放在容器中,供整个程序共享,当用户需要连接时就从池中取,用完再还回去。这样减少了创建和关闭连接的次数,大大提高了程序执行的效率。Mybatis使用了数据库连接池。

4、Mybatis架构

5、使用Mybatis的优点

1)Mybatis封装了JDBC,简化了繁琐的创建与关闭连接步骤;

2)Mybatis自身支持连接池,可以提高程序的效率;

3)Mybatis将SQL配置在mapper文件中,修改SQL时只是修改配置文件,不需要去修改程序,类不用重新编译,以此将程序与SQL解耦,SQL的可维护性、可复用性比较高;

4)对SQL查询后的ResultSet对象,Mybatis会帮我们处理转换成Java对象,不用我们自己去处理;

5) 由于动态SQL的引入使得Mybatis更加灵活,因为连接池、日志与缓存的使用使得Mybatis功能更加强大;

6、#{ }占位符与${ }占位符的区别

#{ }占位符不将SQL写死,可灵活的传入值。它相当于是JDBC里的?占位符,在SQL语句真正执行时,再将传递过来的值放在SQL语句指定的位置,和SQL一起执行。使用#{ }占位符传入的值带引号,传入的是参数对应的值。

${ }占位符传递的值不带引号,传入的是SQL语句本身,通过该占位符传入的值应先添加到map中。

7、优化Mybatis的使用

7.1 加入log4j日志框架

该框架用于打印日志信息,快速定位错误,便于开发调试。使用log4j.properties填写配置信息。

7.2 数据源xxx.properties文件

将数据源信息从XML配置文件中提取出来放到xxx.properties文件中,方便修改与维护,降低程序间的耦合度。

7.3 SQL片段

重复使用的SQL语句写成SQL片段,每次使用时用<include>标签引入该片段即可,这样即使需求变动时要修改也只修改片段即可。

7.4 特殊符号

< 符号在xml文件中被当做标签的开始部分,故应该使用 <![CDATA[ < ]]> 代替。

8、Mybatis架构分析

1)导入mybatis依赖;

2)新建mybatis-config.xml配置文件,配置环境(事务管理方式,数据源)及mappers;

3)实体类对应的映射文件,里面配置了针对该实体的SQL语句映射,通过namespace+id确定到是哪个文件的哪个方法;

4)mybatis底层通过IO流读取配置文件,建立SqlSession工厂,从而建立sqlSession对象执行相应的数据库操作.。

8.1、资源配置技术架构

1)mybatis-configs.xml文件中配置configuration对象,该对象里面配置了environment对象的ManageTransaction方式以及DataSource对象,并配置mapper给出其所在位置;

2)XxxMapper.xml文件中配置相应的数据库语句,与java的POJO对象形成映射关系;

8.2 会话工厂对象创建

3)创建过程:通过IO流读取配置文件,解析IO数据并进行封装,所有信息都会存储到configuration,基于该对象可创建SqlSessionFactory等对象。

8.3 会话对象创建

4)基于SqlSession工厂创建SqlSession对象;

8.4 会话对象应用方式

5)基于SqlSession对象执行SQL语句,一共有两种方式,一是由SqlSession对象对数据库进行操作;二是由SqlSession获取XxxMapper的字节码对象,从而创建代理对象来为之执行对数据库的操作;

SqlSession底层封装了Executor,该对象传入SQL语句执行,传入的参数又调用底层的MapperStatement对象完成对参数的处理与结果集的映射。

基于Mapper接口的会话

获取到mapper接口对应的实现类对象(代理对象)以后,该代理对象基于实现底层的Executor与MapperStatement对象执行SQL操作。

9、 Mybatis缓存机制分析

9.1 Mybatis一级缓存

Mybatis的一级缓存又可以称为SqlSession级缓存,SqlSession关闭时一级缓存失效,在同一个SqlSession内部多次查询数据,后续的查询会从此缓存中取数据。但若从不同的SqlSession查数据,后续的查询每次都会从数据库查。

不同session对象的查询,每次都从数据库取 同一session对象的查询,后续数据从缓存中取

9.2 Mybatis二级缓存

二级缓存有时候又称跨session缓存,可在多个SqlSession间共享数据,若要使用二级缓存则首先需要开启。开启步骤:首先在mybatisConfig.xml中配置settings,添加<setting name="cacheEnabled" value="true" />,相应的mapper文件里添加<cache/>标签开启二级缓存即可测试。(注意:Mybatis的二级缓存会受到sqlSession对象的close()与commit()方法影响,具体可参考:https://blog.csdn.net/zj420964597/article/details/84564440)

二级缓存测试结果

10、Mybatis的配置

10.1 mybatis-config.xml,通过xml文件配置环境与mapper

10.2 通过代码方式配置

10.3 用到的依赖

11、Mybatis使用——xxxMapper.xml文件中几个关键字的使用

1、resultMap

解决数据表中列名与pojo类中属性名称不一致的问题,配置数据表中列和pojo类中属性之间的对应关系。

相关文章

网友评论

      本文标题:Mybatis框架

      本文链接:https://www.haomeiwen.com/subject/rnvyjctx.html