Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

两个字:方便

Mybatis应该是国内用得最多的「数据访问层」框架了,我看了我司的好几个系统,基本都是用Mybatis的。

实话实说,我对Mybatis没有很深入的了解,也仅仅是处于「会用」的阶段上。日常的要加张表,加个字段就是写写 DAO/Mapper 。
为什么没有深入去研究Mybatis的原因很可能是面试其实问得不是特别多,起码我在校招的时候面了很多家公司,也没怎么问我Mybatis的。

Mybatis如果仅仅是要「会用」,入门是非常快的,感觉两三天就可以搞好了。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

认识Mybatis

在前阵子已经总结过了JDBC了,无论是什么的ORM框架(Object Relation Mapping)其实都是在JDBC上封装了一层,底层用的都是JDBC的代码。

众所周知,直接写JDBC的代码的效率是最高的。那为什么要用ORM框架呢??

回想起我第一次实习看到公司代码时的感受:" 卧槽,代码怎么这么多啊。这为什么有这么多的包啊,一直点开都有!"

如果纯用JDBC,只要项目是有点规模的,那我们的项目里代码量一定会很多。最重要的是,很多的代码都是重复的。如果我们的项目里边积累了这么多的重复代码,最致命的问题就是不好维护。

毕竟技术都是服务于业务,公司在选型的时候,选了某ORM框架,肯定也有当时的一个考虑。等到真的是由于使用了某ORM框架导致无法承接掉业务的时,那自然而然就会有优化。

等到真的是由于使用了某ORM框架导致无法承接掉业务的时,那自然而然就会有优化。

不BB了,开始吧。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

最近本人整理不少资料(里面包含了Spring、并发、数据库、Redis、分布式、dubbo、JVM、微服务等。。)
如有有需要的小伙伴们可以点击下面的群号自行领取,一起交流学习共同进步
群号:1149778920 点击这里即可加入
暗号:qf

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

入门

使用Mybatis的步骤大致如下:

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

首先我们需要配Mybatis的一份配置文件,这份配置文件主要配置数据库相关的信息:

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

随后,我们编写一个工具类来获取sqlSession,这个SQLSession相当于JDBC的Connection对象

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
然后编写我们的映射文件,这个映射文件实际上就是对象与数据库的映射关系:
Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
我们在映射文件上使用标签来实现插入:

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
然后调用sqlSession来实现插入即可:

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

效果如下:
Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
看到这里,会不会觉得好像有点复杂?其实这几个步骤都很自然而然的:

  • 要操作数据库,总会有数据库相关的配置吧。(这块实际上就写一次,第一次写完了就不用再写了)

  • 要操作数据库,得告诉程序怎么操作吧,所以有映射文件(可以是XML的映射文件,也可以是注解的方式,反正我们得开个口子去告诉程序怎么执行)

  • 然后我们操作SQLSession去执行命令(这块后面我们可以把SQLSession直接屏蔽掉)

所以,用Mybatis实际上就是写映射文件/注解去告诉程序怎么操作,而映射文件/注解其实就是写SQL,对我们来说并不是难事。

因此,Mybatis入门是真的简单。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

Mybatis细节

动态SQL

动态SQL实际上就是使用Mybatis给我们提供的 if/foreach 之类的标签去判断传递进来的参数有没有值,如果有值我们就拼接参数,如果没有,我们就不拼接。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

缓存

了解Mybatis的一级缓存和二级缓存是什么意思,Mybatis的缓存实现可以用 ehcache 来管理。

如果某些数据查询量大而且不怎么修改的,我们可以考虑使用 ehcache 来对这部分的数据进行缓存,减少数据库的压力。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
Mapper代理

在最开头的例子我们看到我们使用Mybatis在开发中也不见得简单很多,因为有 SQLSession 这一块还是需要我们手动去编写。

我们可以使用Mapper代理的方式屏蔽掉 SQLSession 这块的代码,开发只要写一个接口+一个Mapper.xml(或者注解)就足够了。

那是怎么屏蔽的呢?依靠的是动态代理。为什么可以依靠动态代理来实现呢?因为我们Mapper代理是需要依赖「规则」的,有了「规则」我们就可以通过「反射」去简化我们的代码了。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
****

通过Mapper代理我们已经可以实现(一个接口+一个Mapper映射文件)就可以开发我们的程序了。

而又因为在工作中,CRUD是避免不了的,几乎每增加一张表,都需要有「最基本」的CRUD。

于是程序员们又偷懒了,连「最基本」的CRUD都不想自己写了,于是就有了****。

我们看一下****的配置就差不多能看懂是干啥的了:

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

通过表的结构,生成我们自己的JavaBean以及对应的Mapper接口和Mapper映射文件。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
Mybatis-plus

Mybatis-plus又是程序员偷懒造出的轮子

这款插件说实话我没用过,看了一下官网,大致就是:简单的CRUD,,我连XML都不需要了,API直接帮我们内置了对应的CRUD方法。

有兴趣的同学去学学,都是能提高开发效率的工具。

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

放干货

我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

有需要的小伙伴可以加群1149778920 暗号:qf

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!
Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!

Mybatis与Jdbc相比优势在哪?不比不知道,一比吓一跳!网友:Mybatis 牛逼!