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

作者&投稿:卷修 (若有异议请与网页底部的电邮联系)
~

为什么要学习它呢?

答: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 操作智能分析阻断,也可自定义拦截规则,预防误操作。

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


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


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

1.2、创建数据表

(1)SQL语句



(2) 数据表结构

1.3、 创建java bean

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

1 package com.example.demo.pojo



1.4、 配置application.proprties

数据源使用druid



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

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

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

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

2.2、BaseMapper接口介绍

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

在使用Mybatis-Plus时,核心操作类是BaseMapper接口,其最终也是利用的Mybatis接口编程的实现机制,其默认提供了一系列的增删改查的基础方法,并且开发人员对于这些基础操作不需要写SQL进行处理操作(Mybatis提供的机制就是需要开发人员在mapper.xml中提供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

3.1.wrapper及其子类介绍

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




mybatis与jdbc的关系
MyBatis 是一个基于 JDBC 的持久层框架。它封装了 JDBC 操作的很多细节,使开发者只需要关心 SQL 语句本身,而不需要处理繁琐的 JDBC 操作。JDBC(Java Database Connectivity)是 Java 应用程序连接数据库的标准接口。通过 JDBC,Java 程序可以与各种关系型数据库进行交互。然而,直接使用 JDBC 进行数据...

Spring整合Mybatis一文讲透,手把手带你实操
在Mybatis中,我们可以使用一个接口去定义要执行sql,简化代码如下: 定义一个接口,@Select表示要执行查询sql语句。以下为执行sql代码:Mybatis的目的是:使得程序员能够以调用方法的方式执行某个指定的sql,将执行sql的底层逻辑进行了封装。 这里重点思考以下mapper这个对象,当调用SqlSession的getMapper方法时...

什么是mybatis 为什么要使用my batis
1、定义 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。2、使用原因 MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录...

MyBatis中怎样使用反射获取SQL语句并进行操作?
首先,您需要从MyBatis的映射器接口(Mapper接口)中获取SQL语句。这里我们假设您已经定义了一个映射器接口和相应的XML映射文件。例如,UserMapper接口和对应的UserMapper.xml文件。在MyBatis的配置文件(例如:mybatis-config.xml)中,启用映射器接口的mapperLocations属性,以便MyBatis可以找到XML映射文件:xm...

Java框架MyBatis工作流程是怎样的?
一、Mybatis介绍 MyBatis是一款一流的支持自定义SQL、存储过程和高级映射的持久化框架。MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去 设置参数和获取检索结果。MyBatis能够使用简单的XML格式或者注解进行来配置,能够映射基本数据元素、Map接口和POJOs(普通java对 象)到数据库中的记录。二、My...

好几张表要查询最大id mybatis如何封装
在使用MyBatis进行多张表查询时,如果您需要查询多个表中的最大ID,可以通过以下步骤进行封装:创建一个Java类,用于封装查询结果。例如,可以创建一个名为 "MaxIdResult" 的类。public class MaxIdResult { private Long maxId1; private Long maxId2; \/\/ 可以根据需要添加其他属性或字段 ...

hibernate和mybatis都是持久化框架,有什么区别?
以前没怎么用过mybatis,只知道与hibernate一样是个orm数据库框架。随着使用熟练度的增加,发现它与hibernate区别是非常大的,结合至今为止的经验,总结出以下几点:\\x0d\\x0a1. hibernate是全自动,而mybatis是半自动。\\x0d\\x0ahibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean...

mybatis和ibatis的区别
1、基本信息不同 mybatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)...

mybatis原理是什么?
MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Ordinary Java Objects,普通的 Java对象)映射成数据库中的记录。每个MyBatis应用...

mybatis怎么实现两种数据库的兼容?
MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apachesoftwarefoundation迁移到了googlecode,并且改名为MyBatis。2013年11月迁移到Github。iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQLMaps和DataAccessObjects(DAOs)。

类乌齐县19896259229: mybatis plus该不该用 -
闻曹悦复: IntelliJ idea 开发工具的相关资料很少,加大了大家入手的难度,今天就以mybatis的插件安装做下示例,可能对于已经会用的人不值一提但是对于我们这些天资一般刚开始使用,我想还是会有些帮助.安装步骤:1.下载插件mybatis 插件 插件下载完毕,存放指定位置,文件名默认应该是:mybatis-plus.jar2.打开Intellij idea工具,打开菜单 File --> settings 选择 Plugs,点击Install plug from disk,选择刚刚下载的插件jar文件,确认后,会直接显示mybatis插件和其信息,表示安装成功.3.插件安装后,打开settings,会有Mybatis一项!

类乌齐县19896259229: mybatis - plus不需要写sql语句吗 -
闻曹悦复: 需要写sql语句的,简单的单表操作可以使用mybatis提供的现成方法,复杂的方法必须在xml文件中写sql语句来完成.

类乌齐县19896259229: mybatis怎么写通用查询语句 -
闻曹悦复: 1、亲mybatis是自己写sql语句啊,和hibernate不一样.2、如何知道上面的,你还要知道mysql有一个分页语句叫limit,如:limit(1,10);前面一个参数是起始未知,后面一个是查询多少个.3、oracle的分页方法是嵌套子查询,需要用到rownum这个属性 sql server是top.分页例子:oracle select * from (select emp.*,rownum rn from emp where rownum3; mysql select * from emp limit startindex,maxnum

类乌齐县19896259229: Idea怎么安装Mybatis Generator插件 -
闻曹悦复: IntelliJ idea 开发工具的相关资料很少,加大了大家入手的难度,今天就以mybatis的插件安装做下示例,可能对于已经会用的人不值一提但是对于我们这些天资一般刚开始使用,我想还是...

类乌齐县19896259229: MyBatis中#和$的区别详解 -
闻曹悦复: mybatis中的#和$的区别#相当于对数据 加上 双引号,$相当于直接显示数据1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111", ...

类乌齐县19896259229: mybatis打开二级缓存怎么配置 -
闻曹悦复: 深入了解MyBatis二级缓存 一、创建Cache的完整过程 我们从SqlSessionFactoryBuilder解析mybatis-config.xml配置文件开始:Reader reader = Resources.getResourceAsReader("mybatis-config.xml"); SqlSessionFactory sqlSessionFactory = ...

类乌齐县19896259229: mybatis 怎么配置二级缓存 -
闻曹悦复: 一般来说,一级缓存可以分为一级数据缓存(Data Cache,D-Cache)和一级指令缓存(Instruction Cache,I-Cache).二者分别用来存放数据以及对执行这些数据的指令进行即时解码,而且两者可以同时被CPU访问,减少了争用Cache所造成的冲突,提高了.

类乌齐县19896259229: 如何搭建mybatis开发环境 -
闻曹悦复: 建立一个configuration.xml文件 放在 src/main/resources目录下面 [html] view plain copy <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN" <configuration><typeAliases><...

类乌齐县19896259229: my batis 属性都什么意思 -
闻曹悦复: my basis 我的基础 以上翻译结果来自机器翻译,仅供参考.

类乌齐县19896259229: mybatis怎么设置主键自增 -
闻曹悦复: 设置主键自增,应该是设置具体的数据库,与mybatis没有什么关系吧.以mysql为例,假设主键为id1.可以在创建表的时候设置主键create table tb ( id bigint(20) primary key auto_increment);2...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网