全网最详细地介绍mybatis-plus框架
创始人
2024-05-23 12:54:38

文章目录

  • 1. 简介
  • 2. 特性
  • 3. 支持数据库
  • 4. 框架结构
  • 5. 开始使用
    • 5.1 数据源
    • 5.2 初始化工程
  • 6. 总结

之前使用mybatis框架时,需要写大量的xml配置文件,维护起来比较繁琐。现在使用mybatis-plus,若是简单的curd操作,可以不用写xml文件,这样便降低了对xml的维护。

如下便详细介绍mybatis-plus

1. 简介

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

2. 特性

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

  2. 损耗小:启动即会自动注入基本CURD,性能基本无损耗,直接面向对象操作

  3. 强大的CRUD操作:内置通用Mapper、通用Service,仅仅通过少量配置即可实现单表大部分CRUD操作,更有强大的条件构造器,满足各类使用需求

  4. 支持Lambda形式调用:通过Lambda表达式,方便的编写各类查询条件,无需再担心字段写错

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

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

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

  8. 内置代码生成器:采用代码或者Maven插件可快速生成Mapper 、 Model 、 Service 、 Controller层代码,支持模板引擎,更有超多自定义配置等您来使用

  9. 内置分页插件:基于MyBatis物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通List查询

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

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

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

3. 支持数据库

任何能使用MyBatis进行CRUD,并且支持标准SQL的数据库,如下所示:

  1. MySQL,Oracle,DB2,H2,HSQL,SQLite,PostgreSQL,SQLServer,Phoenix,Gauss ,ClickHouse,Sybase,OceanBase,Firebird,Cubrid,Goldilocks,csiidb,informix,TDengine,redshift

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

4. 框架结构

在这里插入图片描述

5. 开始使用

如下通过一个简单的 Demo 来阐述MyBatis-Plus的强大功能,在此之前,我们假设您已经:

  1. 拥有Java开发环境以及相应IDE

  2. 熟悉Spring Boot

  3. 熟悉Maven

5.1 数据源

  1. 现有一张User表,其表结构如下:
+----+----------+-----------+------+
| id | username | nick_name | age  |
+----+----------+-----------+------+
|  1 | chenxier | 陈希尔    |   18 |
|  2 | zhangsan | 张三      |   22 |
|  3 | lisi     | 李四      |   22 |
|  4 | wanger   | 王二      |   23 |
+----+----------+-----------+------+
  1. 其对应的数据库Schema脚本如下:
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`  (`id` int(11) NOT NULL AUTO_INCREMENT,`username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,`nickname` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,`age` int(11) NULL DEFAULT NULL,PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
  1. 其对应的数据库Data脚本如下:
INSERT INTO `user` VALUES (1, 'chenxier', '陈希尔', 18);
INSERT INTO `user` VALUES (2, 'zhangsan', '张三', 22);
INSERT INTO `user` VALUES (3, 'lisi', '李四', 20);
INSERT INTO `user` VALUES (4, 'wanger', '王二', 23);

5.2 初始化工程

  1. 引入jar
1.83.5.2
com.baomidoumybatis-plus-boot-starter${baomidouMybatisPlus.version}
  1. 配置

application.yml文件中如下配置:

spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverpassword: 123456username: rooturl: jdbc:mysql://localhost:3306/superjson?useUnicode=true&characterEncoding=utf8&useSSL=false
#mybatis配置
mybatis-plus:mapper-locations: classpath:mapper/*.xmltype-aliases-package: com.superjson.superjsonmanager.mapperconfiguration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl# 按下划线转驼峰规则映射数据库字段与java bean属性之间的关系map-underscore-to-camel-case: true# 关闭一级缓存# local-cache-scope: statement# 关闭二级缓存# cache-enabled: falseglobal-config:db-config:id-type: autologic-delete-value: -1logic-not-delete-value: 0

Spring Boot启动类中添加@MapperScan注解,扫描Mapper文件夹:

/*** @author 念兮为美* @datetime 2022/8/5 15:16* @desc superjson框架的启动类*/
@SpringBootApplication
@MapperScan("com.**.mapper")
@Slf4j
public class SuperJsonManagerApplication {public static void main(String[] args) {ConfigurableApplicationContext run =SpringApplication.run(SuperJsonManagerApplication.class, args);// 输出jwt配置信息log.info("jwt config: {}", run.getBean(JwtProperties.class));}
}
  1. 编码

编写实体类User.java

/*** @author 念兮为美* @create 2020-05-29 10:00*/
@AllArgsConstructor
@NoArgsConstructor
@Data
@TableName("user")
public class User implements Serializable {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private int id;private String username;@TableField(value = "nick_name")private String nickname;private Integer age;
}

编写Mapper包下的UserMapper接口

/*** @author 念兮为美* @create 2020-05-29 10:13*/
@Mapper
public interface UserMapper extends BaseMapper {}
  1. 开始使用
class SuperJsonManagerApplicationTests {@Resourceprivate UserMapper userMapper;@Testvoid contextLoads() {System.out.println(("----- selectAll method test ------"));QueryWrapper queryWrapper = new QueryWrapper();queryWrapper.orderByDesc("id");List list = userMapper.selectList(queryWrapper);list.forEach(System.out::println);}

控制台的SQL:

JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@5ac25491] will not be managed by Spring
==>  Preparing: SELECT id,username,nick_name,age FROM user ORDER BY id DESC
==> Parameters: 
<==    Columns: id, username, nick_name, age
<==        Row: 4, wanger, 王二, 23
<==        Row: 3, lisi, 李四, 22
<==        Row: 2, zhangsan, 张三, 22
<==        Row: 1, chenxier, 陈希尔, 18
<==      Total: 4

控制台输出查询结果:

User(id=4, username=wanger, nickname=王二, age=23)
User(id=3, username=lisi, nickname=李四, age=22)
User(id=2, username=zhangsan, nickname=张三, age=22)
User(id=1, username=chenxier, nickname=陈希尔, age=18)

6. 总结

通过以上几个简单的步骤,我们就实现了User表的CRUD功能,甚至连XML文件都不用编写!

从以上步骤中,我们可以看到集成MyBatis-Plus非常的简单,只需要引入starter工程,并配置mapper扫描路径即可。

MyBatis-Plus的强大远不止这些功能,想要详细了解MyBatis-Plus的强大功能?那就前往其官网学习,官网地址如下:

  1. MyBatis-Plus官网:https://mp.baomidou.com

  2. MyBatis-Plus官方文档:https://baomidou.com/pages

  3. 码云项目地址:https://gitee.com/baomidou/mybatis-plus

  4. GitHub地址:https://github.com/baomidou/mybatis-plus

  5. MyBatis-Plus开发组织:https://gitee.com/baomidou

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...