Mybatis-plus 思维导图,让 Mybatis-plus 不再难懂
转载自 Mybatis-plus 思维导图,让 Mybatis-plus 不再难懂
mybatis-plus与mybatis
mybatis
Mybatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
但mybatis有个让我比较头疼的一个问题是sql工作量很大,尤其是字段多的时候。虽然说单表的增删改查操作可以通过mybatis generator工具来生成(或者自己写模板工具生成),但项目开发的过程中总免不了要新添加新字段,这些工具就帮不了我了,我得把新字段写到原来的所有增删改查的sql中。这是个痛苦的过程,特别是当你重复了很多次之后。
mybatis的单表操作也是贼麻烦的事,因为筛选的条件可能会各种各样,所以你不得不写很多动态sql来兼容查询条件,这也让我不能集中精力去处理业务。
每当这时候,我怀念Hibernate了。嘿嘿,Hibernate加字段就贼简单,单表操作也是贼方便。但我依然不喜欢用Hibernate,哈哈。
mybatis-plus
而mybatis-plus这样一个框架,一种集mybatis与hibernate的优点一起的框架。它提供了hibernate的单表CRUD操作的方便同时,又保留了mybatis的特性。
先来看看官方怎么解释mybatis-plus的:
- Mybatis-Plus(简称MP)是一个Mybatis的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
- 我们的愿景是成为
Mybatis
最好的搭档,就像 Contra Game 中的1P、2P,基友搭配,效率翻倍。
带问题去学习,请思考
- mybatis-plus怎么实现单表URUD操作?
- mybatis-plus的底层实现原理是什么?
- mybatis-plus与其他同类框架如mybatis helper有很什么优势?
- 如何集成mybatis-plus快速搭建一个spring boot项目。
特性
从上图可以看出,mybatis-plus不仅仅封装了基本的CRUD操作,还内置了防SQL注入操作、常用的分页插件,还有我最喜欢的ActiveRecord模式。
用过jfinal的人应该都知道ActiveRecord是啥。Active Record 是一种数据访问设计模式,它可以帮助你实现数据对象Object到关系数据库的映射。
常用实体注解
MP通过ORM模式封装了常用的CRUD操作,自然少不了实体注解,先来看看都有哪些注解
其中实体无注解化设置可以如下处理:
- 当数据库的表字段名是驼峰命名时无需注解处理。
- 或者全局配置: 下划线命名 dbColumnUnderline 设置 true , 大写 isCapitalMode 设置 true
但其实我压根就没管过手写过这些注解,使用mp代码生成器自动生成主体后直接覆盖原来的就行了,减少人工的失误,方便快捷。至于@Version与@KeySequence这两个注解,貌似我还真没用过。嘿嘿。。。
简化 CRUD
前面已经说了mp已经简化了mybatis的单表基本操作,先来看看。
相比两种写法,我更喜欢ActiveRecord的模式写法,因为我不用注入userMapper,new了一个对象之后直接调用方法操作就行了。
复杂的查询也很简单,新建一个EntityWrapper作为查询对象,Wrapper接口封装了很多常用的方法。几乎sql能写出来的条件调用Wrapper的方法就能表现出来。
架构原理
参考答案略。
不过我建议你去mp官网或者这里看看,哈哈 -> mybatis-plus 实践及架构原理.pdf
mybatis plus代码生成器 与 mybatis generator
说起mybatis plus代码生成器的代码,我记得以前这这篇文章中介绍过
- 开源项目spring-shiro-training思维导图,让项目不再难懂
现在再拿来用下哈。原理其实很简单,定义好velocity模板(当然你也可以自定义),然后传参数渲染模板生成对应的文件。
我建议你生成的位置最好不要直接覆盖原来的文件,你可能已经有过修改,直接覆盖的话会导致丢失。
而mybatis generator生成的代码就是基本的增删改查和实体。模板好像改不了,灵活性明显不够。
mp插件拓展
mp不仅仅帮我们实现了基本的增删改查操作,同时还扩展了很多实用的插件。让开发的过程更加简单。
分页插件 按如下步骤:
- 自定义查询语句分页(自己写sql/mapper)
- spring 注入 mybatis 配置分页插件
<plugins><!--| 分页插件配置| 插件提供二种方言选择:1、默认方言 2、自定义方言实现类,两者均未配置则抛出异常!| overflowCurrent 溢出总页数,设置第一页 默认false| optimizeType Count优化方式 ( 版本 2.0.9 改为使用 jsqlparser 不需要配置 )| --><!-- 注意!! 如果要支持二级缓存分页使用类 CachePaginationInterceptor 默认、建议如下!! --><plugin interceptor="com.baomidou.mybatisplus.plugins.PaginationInterceptor"><property name="sqlParser" ref="自定义解析类、可以没有" /><property name="localPage" value="默认 false 改为 true 开启了 pageHeper 支持、可以没有" /><property name="dialectClazz" value="自定义方言类、可以没有" /></plugin>
</plugins>
//Spring boot方式
@EnableTransactionManagement
@Configuration
@MapperScan("com.baomidou.cloud.service.*.mapper*")
public class MybatisPlusConfig {/*** 分页插件*/@Beanpublic PaginationInterceptor paginationInterceptor() {return new PaginationInterceptor();}
}
- UserMapper.java 方法内容
public interface UserMapper{//可以继承或者不继承BaseMapper/*** <p>* 查询 : 根据state状态查询用户列表,分页显示* </p>** @param page* 翻页对象,可以作为 xml 参数直接使用,传递参数 Page 即自动分页* @param state* 状态* @return*/List<User> selectUserList(Pagination page, Integer state);
}
- UserServiceImpl.java 调用翻页方法,需要 page.setRecords 回传给页面
public Page<User> selectUserPage(Page<User> page, Integer state) {return page.setRecords(userMapper.selectUserList(page, state));
}
- UserMapper.xml 等同于编写一个普通 list 查询,mybatis-plus 自动替你分页
<select id="selectUserList" resultType="User">SELECT * FROM user WHERE state=#{state}
</select>
逻辑删除插件
逻辑删除的效果 ---> 会在mp自带查询和更新方法的sql后面,追加『逻辑删除字段』=『LogicNotDeleteValue默认值』 删除方法: deleteById()和其他delete方法, 底层SQL调用的是update tbl_xxx set 『逻辑删除字段』=『logicDeleteValue默认值』
配置如下:
- 修改 集成 全局注入器为 LogicSqlInjector
@Bean
public GlobalConfiguration globalConfiguration() {GlobalConfiguration conf = new GlobalConfiguration(new LogicSqlInjector());conf.setLogicDeleteValue("-1");conf.setLogicNotDeleteValue("1");conf.setIdType(2);return conf;
}
- application.yml全局注入值: logicDeleteValue // 逻辑删除全局值 logicNotDeleteValue // 逻辑未删除全局值
mybatis-plus:
mapper-locations: classpath:/mapper/*Mapper.xml#实体扫描,多个package用逗号或者分号分隔
typeAliasesPackage: com.baomidou.springboot.entity
typeEnumsPackage: com.baomidou.springboot.entity.enums
global-config:#主键类型 0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";
id-type: 2#字段策略 0:"忽略判断",1:"非 NULL 判断"),2:"非空判断"
field-strategy: 2
db-column-underline: true#逻辑删除配置
logic-delete-value: 0
logic-not-delete-value: 1
sql-injector: com.baomidou.mybatisplus.mapper.LogicSqlInjector
- 逻辑删除的字段需要注解 @TableLogic
@TableName("tbl_user")
public class UserLogicDelete {private Long id;...@TableField(value = "delete_flag")@TableLogicprivate Integer deleteFlag;
}
spring整合mybatis-plus的优秀案例
基本集成案例 mybatisplus-spring-boot
Java EE(J2EE)快速开发框架 SpringWind
SSM 后台框架 KangarooAdmin
JAVA分布式快速开发基础平台 iBase4J
又一个 SSM 后台管理框架 framework
猫宁Morning公益商城 Morning
简单实用的权限系统 spring-shiro-training Shiro 案例
Mybatis-plus 思维导图,让 Mybatis-plus 不再难懂相关推荐
- Spring思维导图,让Spring不再难懂(aop篇)
2019独角兽企业重金招聘Python工程师标准>>> 什么是aop AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Or ...
- Spring思维导图,让Spring不再难懂(cache篇)
转载自 Spring思维导图,让Spring不再难懂(cache篇) 关于缓存 缓存是实际工作中非常常用的一种提高性能的方法.而在java中,所谓缓存,就是将程序或系统经常要调用的对象存在内存中,再次 ...
- Spring思维导图,让Spring不再难懂(mvc篇)
转载自 Spring思维导图,让Spring不再难懂(mvc篇) spring mvc简介与运行原理 Spring的模型-视图-控制器(MVC)框架是围绕一个DispatcherServlet来设计的 ...
- Spring思维导图,让spring不再难懂(一)
转载自 Spring思维导图,让spring不再难懂(一) 摘要: Spring是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个 ...
- Spring思维导图,让Spring不再难懂(ioc篇)
转载自 Spring思维导图,让Spring不再难懂(ioc篇) 写过java的都知道:所有的对象都必须创建:或者说:使用对象之前必须先创建.而使用ioc之后,你就可以不再手动创建对象,而是从ioc容 ...
- jwt思维导图,让jwt不再难懂
2019独角兽企业重金招聘Python工程师标准>>> 一般情况下,web项目都是通过session进行认证,每次请求数据时,都会把jsessionid放在cookie中,以便与服务 ...
- Spring 思维导图,让 Spring 不再难懂(cache篇)
转载自: java思维导图 开源中国 关于缓存 缓存是实际工作中非常常用的一种提高性能的方法.而在java中,所谓缓存,就是将程序或系统经常要调用的对象存在内存中,再次调用时可以快速从内存中获取对 ...
- 一张思维导图,让正则表达式不再难懂
一张精彩的导图 导图内容解析 语法结构 字符 普通字符:字母.数字.汉字.下划线,匹配与之相同的一个字符 简单转义字符:\n(换行),\t(制表),\\(\本身)和 \^...(\^等有特殊作用的符号 ...
- mybatis学习思维导图
最新文章
- 美国支付巨头Verifone遭遇网络攻击
- Qt-捕获Windows消息
- PMP读书笔记(第2章)
- Android逆向笔记-通过配置文件设置全屏(逆向开发与正向开发)
- Java练习02 打印三角形
- 软件开发工作者的重心是什么
- linux每日命令(11):cat命令
- DELL R730 iDRAC8远程控制卡使用
- 【游戏】基于matlab GUI万年历【含Matlab源码 257期】
- 《通信原理》复习笔记4----第四章信道相关例题
- FastDFS分布文件系统Java客户端使用
- html格式kindle能看吗,Kindle Voyage支持哪些文本格式
- 【不忘初心】Win10 20H2 19042.964_X64_四合一太阳谷图标_[纯净精简版][2.83G](2021.5.1)
- 如何有效的获得高质量的大规模标注数据?
- python热力图参数_python3.5数据处理——百度地图热力图传值
- 时序分析 19 VAR(Vector Autoregression) 向量自回归
- eclipse没有Java EE透视图!
- 邵东一中2021年高考成绩查询,湖南邵阳2020高考成绩,邵东一中势头强劲,包揽邵阳市文理状元...
- Fallout 4 辐射4 技巧统计
- Java操作桌面应用 --- Desktop 类
热门文章
- [设计模式]合成复用原则
- [Java基础]内部类基础
- C++ stringstream输入方式
- 贵州大学计算机专业的导师是谁,贵州大学计算机科学与信息学院导师介绍:王以松...
- oracle导出BOM文件,ORACLE ERP导数据(BOM清单)-备份恢复-Oracle频道-中国IT实验室
- 基于matlab的回波,基于MATLAB回波信号产生与消除.doc
- Codeforces Round #709 (Div. 1) B. Playlist 链表维护 + bfs
- CF741D Arpa’s letter-marked tree and Mehrdad’s Dokhtar-kosh paths 树启 + 状压
- 【NOIP模拟】开車【回退贪心】【multiset】
- 牛客第二场 G.League of Legends-单调队列优化dp