mybatis-plus使用教程

🍅 Java学习路线:搬砖工逆袭Java架构师

🍅 Java经典面试题大全:10万字208道Java经典面试题总结(附答案)

🍅 简介:Java领域优质创作者🏆、CSDN哪吒公众号作者✌ 、Java架构师奋斗者💪

🍅 扫描主页左侧二维码,加入群聊,一起学习、一起进步 

🍅 欢迎点赞 👍 收藏 ⭐留言 📝   

一、简介

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

二、优点

1、无侵入

MyBatis-Plus在MyBatis的基础上进行扩展,只做增强不做改变,引入MyBatis-Plus不会对现有的MyBatis框架产生任何影响,而且MP支持所有MyBatis原生的特性。

2、依赖少

仅仅依赖MyBatis以及MyBatis-Spring

3、损耗小

启动即会注入基本CRUD,性能基本无损耗,直接面向对象操作

4、预防SQL注入

内置SQL注入剥离器,有效预防sql注入攻击

MyBatis 基础知识总结 1】SQL注入

5、通用CRUD操作

内置通用mapper、通用service,仅仅通过少量配置即可实现单表大部分CRUD操作,更有强大的条件构造器,满足各类使用需求,CRUD程序员的噩梦。

6、多种主键策略

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

  • AUTO 数据库ID自增
  • INPUT 用户输入ID
  • ID_WORKER 全局唯一ID,Long类型的主键
  • ID_WORKER_STR 字符串全局唯一ID
  • UUID 全局唯一ID,UUID类型的主键
  • NONE 该类型为未设置主键类型

主键生成的几种方式:

1、数据库自增长

2、UUID

3、Redis生成id

7、支持热加载

mapper对应的xml支持热加载,对于简单的CRUD操作,甚至可以无xml启动。

注意:3.0.6版本上移除了该功能,不过最新快照版已加回来并打上废弃标识,预计3.1.0版本上完全移除

8、支持Active Record

Active Record(简称AR),是一种领域模型模式,特点是一个模型类对应关系型数据库中的一个表,而模型类的一个实例对应表中的一行记录。

MyBatis-Plus对AR的支持,仅需要继承Model类并实现主键指定方法即可。

9、支持代码生成

采用代码或者Maven插件可快速生成mapper、model、service、controller层代码,支持模板引擎,代码生成器类只需修改表名,并输入项目包结构即可,轻松惬意。

10、支持自定义全局通用操作

支持全局通用方法注入

11、支持关键词自动转义

支持数据库关键词自动转移,还可以自定义关键词

12、内置分页插件

基于Mybatis物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于写基本List查询。

分页?初级程序员的噩梦,现在?so easy!

13、内置性能分析插件

可输出sql语句及执行时间,建议开发测试阶段启用。

14、内置全局拦截插件

提供全表delete、update操作,智能分析阻断,预防误操作。

三、BaseMapper

在使用MyBatis-Plus中我们经常用到BaseMapper接口,我就是因为BaseMapper才写的这篇博客,真的是菜鸡的很。

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

BaseMapper类:

package com.baomidou.mybatisplus.core.mapper;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Param;

public interface BaseMapper<T> {
    int insert(T var1);

    int deleteById(Serializable var1);

    int deleteByMap(@Param("cm") Map<String, Object> var1);

    int delete(@Param("ew") Wrapper<T> var1);

    int deleteBatchIds(@Param("coll") Collection<? extends Serializable> var1);

    int updateById(@Param("et") T var1);

    int update(@Param("et") T var1, @Param("ew") Wrapper<T> var2);

    T selectById(Serializable var1);

    List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> var1);

    List<T> selectByMap(@Param("cm") Map<String, Object> var1);

    T selectOne(@Param("ew") Wrapper<T> var1);

    Integer selectCount(@Param("ew") Wrapper<T> var1);

    List<T> selectList(@Param("ew") Wrapper<T> var1);

    List<Map<String, Object>> selectMaps(@Param("ew") Wrapper<T> var1);

    List<Object> selectObjs(@Param("ew") Wrapper<T> var1);

    IPage<T> selectPage(IPage<T> var1, @Param("ew") Wrapper<T> var2);

    IPage<Map<String, Object>> selectMapsPage(IPage<T> var1, @Param("ew") Wrapper<T> var2);
}

上一篇:【MyBatis 基础知识总结 1】SQL注入

下一篇:Oracle数据库访问性能优化

  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
MyBatis-Plus 是一个基于 MyBatis 的增强工具,提供了很多便捷的功能和增强特性,可以简化开发过程。下面是一个简单的 MyBatis-Plus 使用教程: 1. 引入依赖:首先,在你的项目中引入 MyBatis-Plus 的依赖。你可以在 Maven 的 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>{version}</version> </dependency> ``` 请确保将 `{version}` 替换为你希望使用的 MyBatis-Plus 版本号。 2. 配置数据源:在项目的配置文件中,配置数据库连接信息和数据源。你可以使用 Spring Boot 的配置文件(如 application.properties 或 application.yml)来配置。 3. 创建实体类:创建与数据库表对应的实体类,并使用注解标识字段与表的映射关系。MyBatis-Plus 提供了 `@TableName`、`@TableId`、`@TableField` 等注解来实现这些映射关系。 4. 创建 Mapper 接口:创建一个继承自 `BaseMapper` 的接口,并且为该接口指定实体类类型。这个接口将用于定义数据库操作的方法。 5. 编写 SQL 语句:在 Mapper 接口中,使用 MyBatis 的注解或 XML 来编写 SQL 语句。你可以使用 MyBatis-Plus 提供的方法来完成常用的 CRUD 操作,也可以自定义 SQL 语句。 6. 使用 MyBatis-Plus 进行数据库操作:在 Service 层或其他地方,通过注入 Mapper 接口的对象来进行数据库的增删改查操作。MyBatis-Plus 提供了很多便捷的方法,如 `selectList`、`insert`、`update`、`delete` 等。 以上是一个简单的 MyBatis-Plus 使用教程。你可以按照这些步骤来使用 MyBatis-Plus 进行开发,根据具体需求进行配置和扩展。更详细的使用教程和示例代码可以参考 MyBatis-Plus 官方文档或者搜索其他在线教程

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪 吒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值