本文选自知乎上一个回答,觉得作者的思想以及做图都挺好的,故特意摘抄出来,并进行了一些整理。
一、如何学习框架
学习框架时,心里至少要带着下面的疑问:
- 这个框架是负责哪一块的,用在哪一层?
- 没有它之前,前辈们如何解决,有什么缺点?
- 它的出现解决了哪些痛点?
- 它是否也有什么缺点?
二、Mybatis框架
按照答题的形式,通过逐一解答上面的提问来理解MyBatis:
- MyBatis是负责哪一块的,用在哪一层?
MyBatis是对JDBC的封装,负责和数据库打交道,我们在dao层会用到它。
MyBatis出现之前,我们也可以用Hibernate框架,一个非常优秀的ORM框架。
- 没有它之前,前辈们如何解决,有什么缺点?
在MyBatis和Hibernate都没有的、更早更早之前的上古时代,我们的程序猿祖先用的是JDBC,就是“纯原生”的技术。框架说穿了,就是对这些原生技术的封装!
但是JDBC的缺点也十分明显:
所以后来我们都很少在dao层手写JDBC,而是用封装了JDBC的框架,比如Hibernate这样的ORM框架,又比如轻量而优秀的“半自动ORM框架”MyBatis。
这里顺便简单对比下Hibernate和MyBatis。因为同为dao层框架,它们总是被人拿来比较:
- MyBatis解决了JDBC的哪些痛点呢:
三、Mybatis的优缺点
1.sql语句与代码分离,存放于xml配置文件中:
优点:便于维护管理,不用在java代码中找这些语句;
缺点: JDBC方式可以用用打断点的方式调试,但是Mybatis不能,需要通过log4j日志输出日志信息帮助调试,然后在配置文件中修改。
2.用逻辑标签控制动态SQL的拼接:
优点:用标签代替编写逻辑代码;
缺点:拼接复杂SQL语句时,没有代码灵活,拼写比较复杂。不要使用变通的手段来应对这种复杂的语句。
3.查询的结果集与java对象自动映射:
优点:保证名称相同,配置好映射关系即可自动映射或者,不配置映射关系,通过配置列名=字段名也可完成自动映射。
缺点:对开发人员所写的SQL依赖很强。
4.编写原声SQL:
优点:接近JDBC,比较灵活。
缺点:对SQL语句依赖程度很高;并且属于半自动,数据库移植比较麻烦,比如mysql数据库编程Oracle数据库,部分的sql语句需要调整。
另外,推荐一篇非常详细的MyBatis教程:https://blog.csdn.net/hellozpc/article/details/80878563