MyBatis­Plus快速入门源码笔记共享,拿走吧你

MyBatis­Plus快速入门源码笔记共享,拿走吧你,第1张

为什么要学习它呢?

答:MyBatisPlus可以节省我们大量工作时间,所有的CRUD代码它都可以自动化完成!

优点:

1 易于上手和掌握。

2 sql写在xml里,便于统一管理和优化。

3 解除sql与程序代码的耦合。

4 提供映射标签,支持对象与数据库的orm字段关系映射

5 提供对象关系映射标签,支持对象关系组建维护

6 提供xml标签,支持编写动态sql。

MyBatis Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

就像 魂斗罗 中的 1P、2P,基友搭配,效率翻倍。

特性:

无侵入 :只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑。

损耗小 :启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象 *** 作 强大的 CRUD *** 作 :内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD *** 作,更有强大的条件构造器,满足各类使用需求 支持 Lambda 形式调用 :通过 Lambda 表达式,方便地编写各类查询条件,无需再担心字段写错。

支持组件自动生成 :支持多达 4 种主键策略(内含分布式唯一 ID 生成器 Sequence),可自由配置,完美解决主键问题。

支持 ActiveRecord 模式 :支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD *** 作。

支持自定义全局通用 *** 作 :支持全局通用方法注入( Write once, use anywhere )。

内置代码生成器 :采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用 内置分页插件 :基于 MyBatis 物理分页,开发者无需关心具体 *** 作,配置好插件之后,写分页等同于普通 List查询。

分页插件支持多种数据库 :支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库。

内置性能分析插件 :可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询。

内置全局拦截插件 :提供全表 delete 、 update *** 作智能分析阻断,也可自定义拦截规则,预防误 *** 作。

11 、引入mybatis-plus相关maven依赖

引入mybatis-plus在spring boot中的场景启动器

ps:切记不可再在pomxml文件中引入mybatis与mybatis-spring的maven依赖,这一点,mybatis-plus的官方文档中已经说明的很清楚了

12、创建数据表

(1)SQL语句

(2) 数据表结构

13、 创建java bean

根据数据表新建相关实体类

1 package comexampledemopojo

14、 配置applicationproprties

数据源使用druid

ps:在进行crud实验之前,简单对mybatis与mybatis-plus做一个简单的对比

21、mybatis与mybatis-plus实现方式对比

(1)提出问题: 假设我们已存在一张 tbl_employee 表,且已有对应的实体类 Employee,实现 tbl_employee 表的 CRUD *** 作我们需要做什么呢?

(2)实现方式: 基于 Mybatis 需要编写 EmployeeMapper 接口,并手动编写 CRUD 方法 提供 EmployeeMapperxml 映射文件,并手动编写每个方法对应的 SQL 语句 基于 Mybatis-plus 只需要创建 EmployeeMapper 接口, 并继承BaseMapper 接口这就是使用 mybatis-plus 需要完成的所有 *** 作,甚至不需要创建 SQL 映射文件。

22、BaseMapper接口介绍

(1)如何理解核心接口BaseMapper

在使用Mybatis-Plus时,核心 *** 作类是BaseMapper接口,其最终也是利用的Mybatis接口编程的实现机制,其默认提供了一系列的增删改查的基础方法,并且开发人员对于这些基础 *** 作不需要写SQL进行处理 *** 作(Mybatis提供的机制就是需要开发人员在mapperxml中提供sql语句),那样我们可以猜测肯定是Mybatis-Plus完成了BaseMapper接口提供的方法的SQL语句的生成 *** 作。

(2)BaseMapper接口为我们定义了哪些方法

BaseMapper接口源码:

(3) mybatis-plus中常用的注解 1

由于我们的数据表名于实体类的类名不一致,并且实体类于数据表还存在字段名不对应的情况,因此我们需要引入mybatis-plus的注解

编写EmployeeMapper接口继承BaseMapper接口

准备考试环境:

(1)插入

(2)修改

控制台打印出的sql语句

如果我们不设置实体类的email与gender属性,结果是怎样的呢

控制台sql语句:

显然,mybatis-plus为我们做了非空判断,空值的话,默认不更新对应的字段想一想,这是不是类似于mybatis中的动态sql呢

这种处理效果又会带来什么好处呢

(3)查询

selectById方法

selectBatchIds方法

ps:发现该方法底层使用的竟然是sql的in关键字

selectByMap方法

(4)删除

3、不得不提的条件构造器---Wrapper

31wrapper及其子类介绍

(1)Wrapper :条件构造抽象类,最顶端父类,抽象类中提供3个方法以及其他方法

在XML中使用useGeneratedKeys和keyProperty

ibatis是可以直接返回自增主键值的,mybatis是不可以的

你可以按照这种步骤得到

sqlSessioninsert(getNameSpace() + "insertDomain", domain);

int key = domaingetKey();

useGeneratedKey 设置为true, keyProperty为自增主键名称

parameterType String?

那你selectKey获得的id放在哪个对象里呢?

parameterType应该是一个model对象,有id和content两个属性才对

MyBatis-Plus 对 MyBatis 基本零侵入,完全可以与 MyBatis 混合使用,这点很赞。

在涉及到关系型数据库增删查改的业务时,我比较喜欢用 MyBatis-Plus ,开发效率极高。具体的使用可以参考官网,或者自己上手摸索感受一下。

下面简单总结一下在 MyBatis-Plus 中如何使用 ResultMap 。

先看个例子:

有如下两张表:

其中, tb_hero 中的 bid 关联 tb_book 表的 id 。

下面先看 Hero 实体类的代码,如下:

注意了,我特地把 tb_hero 表中的 bid 字段映射成实体类 Hero 中的 bookId 属性。

MyBatis-Plus 打印出的 SQL 为:

没毛病, MyBatis-Plus 会根据 @TableField 指定的映射关系,生成对应的 SQL 。

MyBatis-Plus 打印出的 SQL 为:

也没毛病,可以看到生成的 SELECT 中把 bid 做了别名 bookId 。

比如现在我想连接 tb_hero 与 tb_book 这两张表,如下:

查询 MyBatis-Plus 打印出的 SQL 为:

SQL没啥问题,过滤与分页也都正常,但是此时你会发现 bookId 属性为 null ,如下:

为什么呢?

调用 BaseMapper 中内置的 selectById() 方法并没有出现这种情况啊???

回过头来再对比一下在 HeroMapper 中自己定义的查询与 MyBatis-Plus 自带的 selectById() 有啥不同,还记得上面的刚刚的测试吗,生成的SQL有啥不同?

原来, MyBatis-Plus 为 BaseMapper 中内置的方法生成SQL时,会把 SELECT 子句中 bid 做别名 bookId ,而自己写的查询 MyBatis-Plus 并不会帮你修改 SELECT 子句,也就导致 bookId 属性为 null 。

在这里就是 tb_hero 表中的 bid 字段映射成实体类 Hero 中的 bid 属性。这样当然可以解决问题,但不是本篇讲的重点。

在 @TableName 设置 autoResultMap = true

然后在自定义查询中添加 @ResultMap 注解,如下:

这样,也能解决问题。

下面简单看下源码, @ResultMap("mybatis-plus_实体类名") 怎么来的。

详情见: combaomidoumybatispluscoremetadataTableInfo#initResultMapIfNeed()

注意看上面的字符串 id 的构成,你应该可以明白。

思考: 这种方式的 ResultMap 默认是强绑在一个 @TableName 上的,如果是某个聚合查询或者查询的结果并非对应一个真实的表怎么办呢?有没有更优雅的方式?

基于上面的思考,我做了下面简单的实现:

关键代码其实没有几行,耐心看下应该不难懂。

还是用例子来说明更直观。

下面是一个聚合查询:

其中 BookAgg 的定义如下,在实体类上使用了 @AutoResultMap 注解:

以上就是关于MyBatis­Plus快速入门源码笔记共享,拿走吧你全部的内容,包括:MyBatis­Plus快速入门源码笔记共享,拿走吧你、Mybatis 怎么返回insert插入的主键、mybatis mysql 数据库 insert 插入数据返回主键等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/10148544.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存