MyBatis Plus

warning

(依赖)引入 MyBatis-Plus 之后请不要再次引入 MyBatis 以及 MyBatis-Spring,以避免因版本差异导致的问题。

集成 配置

只需讲将mybatis的sqlSessionFactory 替换为MP的com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean

原生MyBatis

写mapper接口,CRUD方法,mapper.xml配置文件,写sql

MP

只需写接口并继承BaseMapper,不需要写方法,不需写mapper.xml及sql(已经封装好,提供了通用的CRUD操作)

官方文档

剖剖原理

内部肯定还是要写sql的

xxxMapper的本质 org.apache.ibatis.binding.MapperProxy

MapperProxy中sqlSession-->sqlSessionFactory

MyBatis Plus_第1张图片


MyBatis Plus_第2张图片


全局策略配置

驼峰命名转换name="dbColumnUnderline",MP2.3版本默认支持了column的“全局策略”  如属性lastName自动匹配last_name字段。单个指定@TableField(value="last_name")

主键策略name="idType",对所有生效。单个类@TableId(value="id",type=IdType.AUTO)

表前缀策略name="tablePrefix"。单个类@TableName(value="tbl_employee")

插入操作

直接获取自增生成的ID  ID自动生成后,可直接获取。obj.getId()

查询操作

分页 selectPage(new Page<>(2,2))  --基于内存,一般不用这个 。物理分页还需结合分页插件


真正强大的在于... ...

条件构造器EntityWrapper

在使用上Condition与其类似,两者都继承了Wrapper

注意:使用的是数据库字段,不是Java属性


ActiveRecord(AR)

MyBatis Plus_第3张图片

实现:只需让实体类继承Model类且实现主键指定方法即可

基于本身对象来进行操作(本质还是调用原方法,类似语法糖)


代码生成器

对比MBG:

MBG基于xml配置文件,MP基于java代码

MBG生成实体类、mapper接口、mapper映射文件,MP还能生成Service层,Controller层


(依赖)apache-velocity

MyBatis Plus_第4张图片

java代码进行配置(官网有示例代码)


插件机制

MyBatis Plus_第5张图片

xml直接配置:

分页插件(物理分页)

执行分析插件 (防止误删或恶意(mysql5.6.3以上))

性能分析插件(SQL时长)

乐观锁插件(version版本号机制)


自定义全局操作

如果你想实现各种操作,但却不想在mapper映射文件中写sql ... ...

MyBatis Plus_第6张图片

应用之逻辑删除

本质上是更新操作而非删除操作


公共字段自动填充

MyBatis Plus_第7张图片


Oracle主键sequence的使用

MyBatis Plus_第8张图片


视频参考 出错啦! - bilibili.com

你可能感兴趣的:(MyBatis Plus)