当前位置: 首页 > article >正文

MyBatis-Plus(一)

一、 MyBatis-Plus简介

1、简介

MyBatis-Plus (简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生Mybatis-Plus提供了通用的Mapper和Service,可以在不编写任何SQL语句的前提下,快速的实现单表的增删改查(CURD),批量,逻辑删除,分页等操作。只要把MyBatis-Plus的特性到优秀插件,以及多数据源的配置进行详细讲解。

愿景

我们的愿景是成为 MyBatis 最好的搭档,就像魂斗罗中的 1P2P ,基友搭配,效率翻倍。

2、特性

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

  损耗小:启动即会自动注入基本 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 MariaDBOracle DB2 H2 HSQLSQLite PostgreSQLServer 等多种数据库

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

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

3、支持数据库

任何能使用MyBatis进行 CRUD, 并且支持标准 SQL 的数据库,具体支持情况如下

   MySQL Oracle  DB2  H2  HSQL SQLite  PostgreSQL SQLServer  Phoenix Gauss  ClickHouse Sybase OceanBase  Firebird Cubrid Goldilocks csiidb

  达梦数据库,虚谷数据库,人大金仓数据库,南大通用(华库)数据库,南大通用数据库,神通数据 库,瀚高数据库

4、框架结构

5、代码及文档地址

官方地址: http://mp.baomidou.com

代码发布地址:

Github: GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development

Gitee: mybatis-plus: mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com低代码组件库 http://aizuda.com

文档发布地址: https://baomidou.com/pages/24112f

二、入门案例

1、开发环境

IDE idea 2019.2

JDKJDK8+

构建工具:  maven 3.5.4

MySQL版本:  MySQL 5.

Spring Boot2.6.3

MyBatis-Plus3.5.1

2、创建数据库及表

a>创建表

b>添加数据

INSERT INTO user (id, name, age, email) VALUES

(1, 'Jone', 18, 'test1@baomidou.com'),

(2, 'Jack', 20, 'test2@baomidou.com'),

(3, 'Tom', 28, 'test3@baomidou.com'),

(4, 'Sandy', 21, 'test4@baomidou.com'),

(5, 'Billie', 24, 'test5@baomidou.com');

3、创建Spring Boot工程

a>初始化工程

CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTER SET utf8mb4 */; use `mybatis_plus`;

CREATE TABLE `user` (

`id` bigint(20) NOT NULL COMMENT '主键ID',

`name` varchar(30) DEFAULT NULL COMMENT '姓名 ',

`age` int(11) DEFAULT NULL COMMENT '年龄 ',

`email` varchar(50) DEFAULT NULL COMMENT '邮箱 ',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

b>引入依赖

INSERT INTO user (id, name, age, email) VALUES

(1, 'Jone', 18, 'test1@baomidou.com'),

(2, 'Jack', 20, 'test2@baomidou.com'),

(3, 'Tom', 28, 'test3@baomidou.com'),

(4, 'Sandy', 21, 'test4@baomidou.com'),

(5, 'Billie', 24, 'test5@baomidou.com');

3、创建Spring Boot工程

a>初始化工程

使用 Spring Initializr 快速初始化一个 Spring Boot 工程

b>引入依赖

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

<scope>test</scope>

</dependency>

<dependency>

<groupId>com.baomidou</groupId>

<artifactId>mybatis-plus-boot-starter</artifactId>

<version>3.5.1</version>

</dependency>

<dependency>

<groupId>org.projectlombok</groupId>

<artifactId>lombok</artifactId>

<optional>true</optional>

</dependency>

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<scope>runtime</scope>

</dependency>

</dependencies>

c>idea中安装lombok插件

4、编写代码

a>配置application.yml

spring:

# 配置数据源信息

datasource:

# 配置数据源类型

type: com.zaxxer.hikari.HikariDataSource

# 配置连接数据库信息

driver-class-name: com.mysql.cj.jdbc.Driver

url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf- 8&useSSL=false

username: root

password: 123456

注意:

1、驱动类driver-class-name

spring boot 2.0(内置jdbc5驱动),驱动类使用:

driver-class-name: com.mysql.jdbc.Driver

spring boot 2.1及以上(内置jdbc8驱动),驱动类使用:

driver-class-name: com.mysql.cj.jdbc.Driver

否则运行测试用例的时候会有 WARN 信息

2、连接地址url

MySQL5.7版本的url

jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false

MySQL8.0版本的url

jdbc:mysql://localhost:3306/mybatis_plus?

serverTimezone=GMT%2B8&characterEncoding=utf-8&useSSL=false

否则运行测试用例报告如下错误:

java.sql.SQLException: The server time zone value'Öйú±ê׼ʱ¼ä' is unrecognized or represents more

b>启动类

    Spring Boot启动类中添加@MapperScan注解,扫描mapper

@SpringBootApplication

@MapperScan("com.atguigu.mybatisplus.mapper")

public class MybatisplusApplication {

public static void main(String[] args) {

SpringApplication.run(MybatisplusApplication.class, args); }

}

c>添加实体

@Data //lombok注解

public class User {

private Long id;

private String name;

private Integer age;

private String email;

}

User类编译之后的结果:

d>添加mapper

BaseMapperMyBatis-Plus提供的模板mapper,其中包含了基本的CRUD方法,泛型为操作的 实体类型

public interface UserMapper extends BaseMapper<User> {

}

e>测试

@SpringBootTest

public class MybatisPlusTest {

@Autowired

private UserMapper userMapper;

@Test

public void testSelectList(){

//selectList()根据MP内置的条件构造器查询一个list集合,null表示没有条件,即查询所有

userMapper.selectList(null).forEach(System.out::println);

}

}

结果:

注意:

IDEAuserMapper 处报错,因为找不到注入的对象,因为类是动态创建的,但是程序可以正确 的执行。

为了避免报错,可以在mapper接口上添加 @Repository 注解

f>添加日志

application.yml中配置日志输出

# 配置MyBatis日志

mybatis-plus:

configuration:

log-impl: org.apache.ibatis.logging.stdout.StdOutImpl


http://www.kler.cn/a/443788.html

相关文章:

  • k8s迁移——岁月云实战笔记
  • VLM--CLIP作分类任务的损失函数
  • 人工智能ACA(四)--机器学习基础
  • Activiti开启流程实例
  • mapStateToProps
  • 【定理证明工具调研】Coq, Isabelle and Lean.
  • 论文笔记:是什么让多模态学习变得困难?
  • Vmware 安装Ubuntu系统 服务器版本
  • 盈养科技二面
  • 3D可视化引擎HOOPS Visualize与HOOPS Luminate Bridge的功能与应用
  • 低比特语言模型 是一种利用较少比特数进行语言建模的技术
  • Nginx(Linux之Ubuntu)
  • 力扣hot100——矩阵
  • 领域驱动设计的学习分享
  • xmlrpc.php有什么用以及为何建议禁用
  • 【数据集】生菜病害检测数据集530张6类YOLO+VOC格式
  • ES6学习Symbol(五)
  • C语言与C++
  • go字符、字符串等
  • 3D 高斯溅射 (Gaussian Splatting)技术,一种实现超写实、高效渲染的突破性技术
  • 关于Unity VFX 在Spawn状态的一些笔记
  • 深入理解Kafka:核心设计与实践原理读书笔记
  • python练习:“互联网 +” 时代的出租车资源配置的数学建模(一)
  • Upload-labs 靶场(通关攻略)
  • 安当SMS集中式凭据管理系统,HashiCorp Vault的国产化替代解决方案
  • 轻量级+鲸鱼优化!WOA-LightGBM鲸鱼优化算法优化轻量级梯度提升机分类预测Matlab实现