MyBatis-plu 和 JPA
- 前言
- 一、说下相同点
- 二、差异点
- 一、从实现来说:CURD实现方式不一样
- 二、分页上
- 三、雪花id
- 四、伪删除
- 五、子类排除父类的字段
- 总结
前言
提示:这里可以添加本文要记录的大概内容:
说来尴尬,工作这么多年,还没用过JPA。
自己用了下querydsl-jpa,和常用的mybatis-plus进行了下对比。
整体来说都有自己的优点:mybatis-plus更加轻量,JPAQuery可以实现联表查询。
一、说下相同点
1:都包装了简单的CRUD,可以直接用
2:都支持自定义sql(如:@Select())
3:都支持二级缓存
二、差异点
一、从实现来说:CURD实现方式不一样
mybatis-plus :
Mapper(Dao)类extends BaseMapper
实现类里extends ServiceImpl
接口类extends IService
jpa:
repository类(等同于Mapper/DAO类)extends JpaRepository
但是,jpa在定义好数据库类(如:User类)后,需要compile一下(会生产QUser类)
二、分页上
mybatis-plus :
有自己的分页插件,也能很好的支持第三方插件,如:pageHelperjpa:
需要自己处理count查询
三、雪花id
mybatis-plus:
自带jpa:
需要自己实现
四、伪删除
mybatis-plus:
有@TableLogicjpa:
需要自己实现
五、子类排除父类的字段
mybatis-plus:
子类里重新定义父类里的字段,用@transientjpa:
暂不能解决
总结
归纳下大佬们的理解:jpa:
1:默认使用hibernate作为ORM
2:更加偏向于面向对象
3:支持多表关联(用JPAQuery,不是像mybatis那样写在xml)
mybatis:
1:避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
2:更偏向于面向数据(面向关系),致命优点:简单、可读性强
网上一直说的性能:
两个ORM框架的效率不会查特别多(毕竟一次插入万级数据,且要求ms级别,这种毕竟是极少数)。平时开发中,几百条数据的情况下,两者都差不多的。
到底用哪个
第一:跟着公司走,毕竟大头兵没啥发言权
第二:我个人更推荐mybatis-plus,尽量不写xml。联表逻辑放在代码里实现(jvm运行代码很快的,避免for内部查库)
第三:JPA的学习成本比MyBatis-plus大
最后声明下:本文章没有商用,且参考了网上许多大佬的文章