Mybatis框架

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类中属性之间的对应关系。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,520评论 0 4
  • MyBatis 理论篇 [TOC] 什么是MyBatis  MyBatis是支持普通SQL查询,存储过程和高级映射...
    有_味阅读 2,897评论 0 26
  • # 前言 在java程序员的世界里,最熟悉的开源软件除了 Spring,Tomcat,还有谁呢?当然是 Mybat...
    莫那一鲁道阅读 3,290评论 3 11
  • 之前在spring mvc + mybatis项目中对mybatis的使用有了一定的掌握,但对于其内部的具体实现并...
    天羽天阅读 1,087评论 0 0
  • 1. 病房床头柜上,手机一直震动个不停。 “王伯伯,你手机一直在响,你不接吗?” 小葫芦头忍不住打断讲得正讲的眉飞...
    薛瘦脱阅读 445评论 0 4