Mybits plus详解

一、了解Mybatis-Plus

1、Mybatis-Plus介绍

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

官网:https://mybatis.plus/ 或 https://mp.baomidou.com/

2、代码以及文档

文档地址:mybatis.plus

源码地址:https://github.com/baomidou/mybatis-plus

3、特性

无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作, 更有强大的条件构造器,满足各类使用需求
支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、
SQLServer2005、SQLServer 等多种数据库
支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解 决主键问题
支持 XML 热加载:Mapper 对应的 XML 支持热加载,对于简单的 CRUD 操作,甚至可以无 XML 启动
支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操 作
支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
支持关键词自动转义:支持数据库关键词(order、key......)自动转义,还可自定义关键词
内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码, 支持模板引擎,更有超多自定义配置等您来使用
内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通List 查询
内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作
内置 Sql 注入剥离器:支持 Sql 注入剥离,有效预防 Sql 注入攻击

二、快速开始

对于Mybatis整合MP有常常有三种用法,分别是Mybatis+MP、Spring+Mybatis+MP、Spring Boot+Mybatis+MP。

ac9a466fc97542a79c72cd4d7c4cd442.png

 

-- 创建测试表 
CREATE TABLE `tb_user` ( 
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID', 
   `user_name` varchar(20) NOT NULL COMMENT '用户名', 
   `password` varchar(20) NOT NULL COMMENT '密码', 
   `name` varchar(30) DEFAULT NULL COMMENT '姓名', 
   `age` int(11) DEFAULT NULL COMMENT '年龄', 
   `email` varchar(50) DEFAULT NULL COMMENT '邮箱', 
   PRIMARY KEY (`id`) 
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; 

-- 插入测试数据 
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES 
('1', 'zhangsan', '123456', '张三', '18', 'test1@itcast.cn'); 
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES 
('2', 'lisi', '123456', '李四', '20', 'test2@itcast.cn'); 
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES 
('3', 'wangwu', '123456', '王五', '28', 'test3@itcast.cn'); 
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES 
('4', 'zhaoliu', '123456', '赵六', '21', 'test4@itcast.cn'); 
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES 
('5', 'sunqi', '123456', '孙七', '24', 'test5@itcast.cn'); 1

 

2.正常创建一个Spring工程

 

导入依赖:

<?xml version="1.0" encoding="UTF-8"?> 
<project xmlns="http://maven.apache.org/POM/4.0.0" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
     <modelVersion>4.0.0</modelVersion> 

     <groupId>cn.itcast.mp</groupId> 
     <artifactId>itcast-mybatis-plus</artifactId> 
     <version>1.0-SNAPSHOT</version> 
     <modules> 
          <module>itcast-mybatis-plus-simple</module> 
     </modules> 
     <packaging>pom</packaging> 

     <dependencies> 
         <!-- mybatis-plus插件依赖 --> 
         <dependency> 
             <groupId>com.baomidou</groupId> 
             <artifactId>mybatis-plus</artifactId> 
             <version>3.1.1</version> 
         </dependency> 
         <!-- MySql --> 
         <dependency> 
             <groupId>mysql</groupId> 
             <artifactId>mysql-connector-java</artifactId> 
             <version>5.1.47</version> 
         </dependency> 
         <!-- 连接池 --> 
         <dependency> 
             <groupId>com.alibaba</groupId> 
             <artifactId>druid</artifactId> 
             <version>1.0.11</version> 
         </dependency> 
         <!--简化bean代码的工具包--> 
         <dependency> 
             <groupId>org.projectlombok</groupId> 
             <artifactId>lombok</artifactId> 
             <optional>true</optional> 
             <version>1.18.4</version> 
         </dependency> 
         <dependency> 
             <groupId>junit</groupId> 
             <artifactId>junit</artifactId> 
             <version>4.12</version> 
         </dependency> 
         <dependency> 
             <groupId>org.slf4j</groupId> 
             <artifactId>slf4j-log4j12</artifactId> 
             <version>1.6.4</version> 
         </dependency> 
     </dependencies> 
     <build> 
         <plugins> 
            <plugin> 
                <groupId>org.apache.maven.plugins</groupId> 
                <artifactId>maven-compiler-plugin</artifactId> 
                <configuration> 
                    <source>1.8</source> 
                    <target>1.8</target> 
                </configuration> 
         </plugin> 
     </plugins> 
 </build> 

</project> 
三、通用CRUD

插入操作:

/**
* 插入一条记录 
*
* @param entity 实体对象 
*/ 
int insert(T entity); 
更新操作:

/**
* 根据 ID 修改 
*
* @param entity 实体对象 
*/ 
int updateById(@Param(Constants.ENTITY) T entity); 
删除操作:

/**
* 根据 ID 删除 
*
* @param id 主键ID 
*/ 
int deleteById(Serializable id);
查询操作:

/**
* 根据 ID 查询 
*
* @param id 主键ID 
*/ 
T selectById(Serializable id); 
四、配置

在MP中有大量的配置,其中有一部分是Mybatis原生的配置,另一部分是MP的配置,详情:mybatis.plus onfifig/

1、基本配置

configLocation

MyBatis 配置文件位置,如果您有单独的 MyBatis 配置,请将其路径配置到 configLocation 中。 MyBatis

Configuration 的具体内容请参考MyBatis 官方文档。

mapperLocations

MyBatis Mapper 所对应的 XML 文件位置,如果您在 Mapper 中有自定义方法(XML 中有自定义实现),需要进行该配置,告诉 Mapper 所对应的 XML 文件位置。

typeAliasesPackage

MyBaits 别名包扫描路径,通过该属性可以给包中的类注册别名,注册后在 Mapper 对应的 XML 文件中可以直接使用类名,而不用使用全限定的类名(即 XML 中调用的时候不用包含包名)。

2、进阶配置

本部分(Confifiguration)的配置大都为 MyBatis 原生支持的配置,这意味着您可以通过 MyBatis XML 配置文件的形 式进行配置。

mapUnderscoreToCamelCase

类型: boolean
默认值: true
是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN(下划线命名)到经典 Java 属性名 aColumn(驼峰命名)的类似映射。

cacheEnabled

类型: boolean
默认值: true
全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存,默认为 true。

示例:

mybatis-plus.configuration.cache-enabled=false
3、DB 策略配置

idType

类型: com.baomidou.mybatisplus.annotation.IdType
默认值: ID_WORKER
全局默认主键类型,设置后,即可省略实体对象中的@TableId(type = IdType.AUTO)配置

tablePrefifix

类型: String
默认值: null
表名前缀,全局配置后可省略@TableName()配置。

五、条件构造器

在MP中,Wrapper接口的实现类关系如下:

7f0b8744e7c6484a958c71e78447424f.png

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值