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
全局策略配置
驼峰命名转换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)
实现:只需让实体类继承Model类且实现主键指定方法即可
基于本身对象来进行操作(本质还是调用原方法,类似语法糖)
代码生成器
对比MBG:
MBG基于xml配置文件,MP基于java代码
MBG生成实体类、mapper接口、mapper映射文件,MP还能生成Service层,Controller层
(依赖)apache-velocity
java代码进行配置(官网有示例代码)
插件机制
xml直接配置:
分页插件(物理分页)
执行分析插件 (防止误删或恶意(mysql5.6.3以上))
性能分析插件(SQL时长)
乐观锁插件(version版本号机制)
自定义全局操作
如果你想实现各种操作,但却不想在mapper映射文件中写sql ... ...
应用之逻辑删除
本质上是更新操作而非删除操作
公共字段自动填充
Oracle主键sequence的使用
视频参考 出错啦! - bilibili.com