此篇只做总结和对比 不做具体的操作和实现
Mybatis
Mybatis 是一款半自动的ORM框架,而比Mybatis更早流行的是Hibernate全自动框架。
现在除了老项目,大部分都是Mybatis框架,作为数据服务层的操作。
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
然后我刚刚搜索Mybatis官网 http://mybatis.org/spring/zh/index.html 的时候,发现了 Mybatis-spring 其实就是Mybatis整合Spring 如下图:
现在使用的Mybatis的人越来越多 自然而然就对Mybatis的使用想提出更好更快捷的解决方案。于是乎,通用Mapper和MybatisPlus横空出世。 但是标题为啥还有Jpa和SpringData呢?不慌
Jpa和SpringData是和Hibernate类似的框架,也是用其来操作数据库,执行CRUD的操作,Jpa支持通过注解的方式来指定数据表名,id,列等,也提出了 JPQL 语言——和SQL语言很相似。
SpringData 是Spring的一个子项目 支持的数据库
SpringData 项目所支持 NoSQL 存储:
MongoDB (文档数据库)
Neo4j(图形数据库)
Redis(键/值存储)
Hbase(列族数据库)
SpringData 项目所支持的关系数据存储技术:
JDBC JPA
SpringData中的的接口方法支持通过注解来实现 SQL语句
@Query("select o from UserModel o where o.name like ?1%")
public List<UserModel> findByUuidOrAge(String name);
@Query("select o from UserModel o where o.name like %?1")
public List<UserModel> findByUuidOrAge(String name);
@Query("select o from UserModel o where o.name like %?1%")
public List<UserModel> findByUuidOrAge(String name);
这点和Mybatis有共通之处
然后Jpa和SpringData也提供了使用类来替代具体的SQL语句的拼接,使得我们操作逻辑数据代码的时候,可以通过类和对象来实现,而无需我们去写SQL代码。是不是狠爽。
后来我在学习了Mybatis逆向工程的时候,我发现,这和SpringData的原理一样的啊,都是可以通过对象来操作数据表和SQL语句,那么Mybatis逆向工程,也就很好理解了。
假如不使用Mybatis逆向工程,那么几十张表去自己写映射,CRUD,那恐怕要疯了。使用Mybatis逆向工程,稍稍配置一下,然后运行一下,就全部生成出来,比较省事。当然了,生成的文件也是很多的,然后一个 xxxmapper.xml 映射文件,有很多映射的SQL语句,因为生成了单表操作的所有SQL语句。当然了,无论是哪个生成的SQL 或者是配置文件类等,都是仅仅支持单表操作。
当然,Mybatis逆向工程挺好用,但是也有些不足,弄出了很多的文件,假如表太多,那么生成的文件就会很多,不是很好管理,也就是很多逻辑不仅仅只是单表操作,还有很多是多表操作的。那么这样写的话就比较痛苦了
然后下一个就是通用Mapper的出现 自定义的 xxxMapper 接口只需要实现官方的 Mapper<T>就可以了,自动就有了这些单表操作的方法,是不是很爽?当然,通用Mapper是基于Mybatis的升级。
通用Mapper会有一些注解的使用,这里的注解和Jpa里面的注解很类似,也有 Table注解,Column注解等。
Mapper<T> 接口继承了很多接口,然后不同的接口有不同的方法。通过这些方法,我们可以实现基于单表的增删改查。然后支持QBC查询 和上面的两张图巨类似!同时通用Mapper支持定制接口,也就是可以自己实现自己需要的方法的接口。
通用Mapper支持二级缓存,只需要一个注解就可以搞定,也支持类型处理器——复杂类型(除了基本类型和String类型之外的类型)。
总体感觉通用Mapper使用不是很困难
MybatisPlus 国内大牛出产,对Mybatis只做增强,不做改变。
同样的,搭建好环境之后 针对 xxxMapper 接口继承BaseMapper<T> 接口,那么BaseMapper<T>有啥?这还用猜?单表的基本操作都有!
然后呢,MP也提供了 条件构造器 EntityWrapper 使用的是数据库字段。也就是下图:
这个时候,操作数据库SQL语句就是在操作类的属性,是不是巨爽?