Spring Boot学习随笔- 集成MyBatis-Plus,第一个MP程序(环境搭建、@TableName、@TableId、@TableField示例)

学习视频:【编程不良人】Mybatis-Plus整合SpringBoot实战教程,提高的你开发效率,后端人员必备!

引言

MyBatis-Plus是一个基于MyBatis的增强工具,旨在简化开发,提高效率。它扩展了MyBatis的功能,提供了许多实用的特性,包括强大的CRUD操作、条件构造器、分页插件、代码生成器等。MyBatis-Plus的目标是简化开发,提供更便捷的操作数据库的方式。

MyBatis-Plus的主要特性包括:

  1. CRUD操作的增强功能:MyBatis-Plus提供了丰富的CRUD操作方法,包括批量插入、批量更新、链式查询等,简化了数据操作的流程。
  2. 条件构造器:MyBatis-Plus内置了条件构造器,可以通过简单的方法链式调用来构建复杂的查询条件,避免手写SQL语句,提高了开发效率。
  3. 分页插件:MyBatis-Plus提供了强大的分页插件,支持多种数据库的分页查询,开发者可以轻松实现分页查询功能。
  4. 代码生成器:MyBatis-Plus内置了代码生成器,可以根据数据库表自动生成Entity、Mapper、Service、Controller等代码,减少了重复的CRUD代码编写工作。
  5. 乐观锁插件:MyBatis-Plus提供了乐观锁的支持,可以通过注解的方式实现乐观锁功能,确保数据的一致性。

SpringBoot集成MyBatis-Plus

第一个MyBatisPlus程序

创建项目,提前引入支持的依赖(热部署、mysql、lombok、Web)

引入依赖

<!--已包含mybatis依赖-->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.3.2</version>
</dependency>
<!-- 引入阿里巴巴连接池-->
<dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.19</version>
</dependency>

配置文件

mapper文件映射和实体别名,mybatisplus已经配置了,所以不需要再写了。

spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/ems?characterEncoding=UTF-8username: rootpassword: root

包扫描配置、实体类

@Data
public class User {private Long id;private String name;private Integer age;private String email;private Long managerId;private LocalDateTime createTime;
}
@SpringBootApplication
@MapperScan("com.mp.dao")
public class MyBatisPlusLessionApplication {public static void main(String[] args) {SpringApplication.run(MyBatisPlusLessionApplication.class, args);}
}

实现mapper接口

  • 使用**mybatisplus** 的增强接口 BaseMapper

    // BaseMapper的泛型一定要写,否则返回不了数据
    public interface UserMapper extends BaseMapper<User> {}
    

测试

@SpringBootTest
class MyBatisPlusLessionApplicationTests {@Autowiredprivate UserMapper userMapper;@Testpublic void select() {**List<User> list = userMapper.selectList(null);// null指的是没有查询条件**list.forEach(System.out::println);}
}

返回数据成功

以下是BaseMapper中常用的方法:

方法名描述
insert插入一条记录
insertBatch批量插入记录
deleteById根据ID删除记录
deleteByMap根据Map条件删除记录
delete根据条件删除记录
updateById根据ID更新记录
update根据条件更新记录
selectById根据ID查询记录
selectBatchIds根据ID列表批量查询记录
selectByMap根据Map条件查询一条记录
selectOne查询满足条件的一条记录
selectCount查询满足条件的记录数
selectList查询满足条件的记录列表
selectMaps查询满足条件的记录,返回Map列表
selectObjs查询满足条件的记录,返回Object列表
selectPage分页查询记录

基本使用

  • 日志配置

    logging:level:root: warn # 根日志com.mp.dao: trace # 指定包级别pattern:console: '%p%m%n' # 格式
    

Insert

@Test
public void insert() {User user = new User();user.setName("刘东");user.setAge(21);user.setEmail("xiaohei@qq.com");user.setManagerId(1L);user.setCreateTime(LocalDateTime.now());int rows = userMapper.insert(user);System.out.println("影响记录数:"+rows);
}

运行结果,成功插入数据

注意:我们在set中并没有插入id,但是运行结果成功插入了一串id值,因为这是mybatis-plus基于雪花算法实现的自增id。

常用注解 @TableName@TableId@TableFieId

@Data
@TableName("mp_user")
public class User {@TableIdprivate Long userId;@TableField("name")private String realName;private Integer age;private String email;private Long managerId;private LocalDateTime createTime;
}

**@TableName**用于指定实体类对应的数据库表名,如果不指定,就以类名作为映射关系

@TableId 注解来指定主键

@TableFieId 用于标识实体类中的字段与数据库表中的列的映射关系。

排除非表字段的三种方式

  1. transient 【不推荐】

    private transient String remark;
    

    不推荐在MyBatis Plus中使用Java语言中的**transient关键字来排除非表字段的原因是,transient关键字主要用于Java对象的序列化过程,用于标记不需要序列化的字段。但是,对于数据库操作而言,transient**关键字并不会影响字段的持久化行为,因为它只是在Java对象的序列化和反序列化过程中起作用。

  2. static 【不推荐】

    private static String remark;
    
  3. @TableField(exist = false) 【推荐】

    @TableField(exist = false)
    private static String remark;
    

    在进行数据库操作时,MyBatis-Plus会自动排除带有**@TableField(exist = false)**注解的非表字段,不会将它们包含在生成的SQL语句中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/585344.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Visual Studio 配置DLL

我们在用Visual Studio进行开发时&#xff0c;如果没有正确配置DLL&#xff0c;就会出现类似“丢失***.dll”的错误。DLL配置有哪些方法&#xff1f; 1、手动复制 将dll文件拷贝到生成的.exe所在的文件夹里 2、配置环境 在右键属性->配置属性->调试->环境&#xf…

Linux之定时任务调度

crond crond是Linux系统中的一个守护进程&#xff0c;主要用于周期性地执行某种任务或等待处理某些事件。而crondtab是配套的工作&#xff0c;用于定时任务的设置。 语法 crontab [选项]常用选项 入门案例 执行crontab -e命令输入任务到调度文件中 */1 * * * * ls -l /et…

鸿蒙原生应用再添新丁!爱奇艺入局鸿蒙

鸿蒙原生应用再添新丁&#xff01;爱奇艺 入局鸿蒙 来自 HarmonyOS 微博12月29日消息&#xff0c;#爱奇艺完成鸿蒙原生应用Beta版#作为中国头部在线视频平台&#xff0c;爱奇艺 完成鸿蒙原生应用Beta版&#xff0c;将以丰富的正版高清视频资源促进鸿蒙生态的进一步繁荣&#x…

准备用vscode代替sourceinsight

vscode版本1.85.1 有的符号&#xff0c;sourceinsight解析不到。 看网上说vscode内置了ripgrep&#xff0c;但ctrlshiftf在文件里查找的时候&#xff0c;速度特别慢&#xff0c;根本不像ripgrep的速度。ripgrep的速度是很快的。 但今天再查询&#xff0c;速度又很快了&#x…

双击编辑el-table的单元格数据

(1) el-table刷新要求绑定el-table的key要发生变化才会刷新 (2) 单元格双击事件 cell-dblclick (3) 往row里面添加一个属性来唯一标识某一行的数据&#xff0c;双击时使这特殊属性为true&#xff0c;输入框失去焦点时则设置特殊属性为false&#xff0c;并且输入框的显示与隐藏…

SparkStreaming_window_sparksql_reids

1.5 window 滚动窗口滑动窗口 window操作就是窗口函数。Spark Streaming提供了滑动窗口操作的支持&#xff0c;从而让我们可以对一个滑动窗口内的数据执行计算操作。每次掉落在窗口内的RDD的数据&#xff0c;会被聚合起来执行计算操作&#xff0c;然后生成的RDD&#xff0c;会…

m3u8网络视频文件下载方法

在windows下&#xff0c;使用命令行cmd的命令下载m3u8视频文件并保存为mp4文件。 1.下载ffmpeg&#xff0c;访问FFmpeg官方网站&#xff1a;https://www.ffmpeg.org/进行下载 ffmpeg下载&#xff0c;安装&#xff0c;操作说明 https://blog.csdn.net/m0_53157282/article/det…

下载和安装AD14 - Altium Designer 14.3.20.54863

这个版本应该还支持XP 系统[doge]&#xff0c;总之就是想安装一下&#xff0c;没什么特别的意义。 下载 资源来自毛子网站&#xff1a;https://rutracker.net/forum/viewtopic.php?t5140739&#xff0c;带上个网页翻译插件就行。要用磁力链接下载&#xff0c;推荐用qbittorr…

RabbitMQ之快速入门、上手

前言 学习一样新技术、新框架&#xff0c;最重要的是学习其思想、原理。即原理性思维。 如果是因为工作原因&#xff0c;需要快速上手RabbitMQ&#xff0c;本篇或许适合你。 核心概念 Connection&#xff1a;publisher&#xff0f;consumer 和 broker 之间的 TCP 连接Channel…

Android 理解Context

文章目录 Android 理解ContextContext是什么Activity能直接new吗&#xff1f; Context结构和源码一个程序有几个ContextContext的作用Context作用域获取ContextgetApplication()和getApplicationContext()区别Context引起的内存泄露错误的单例模式View持有Activity应用正确使用…

Springboot2+mybatisplus+多数据源更换mysql数据库为pgsql

前提:Springboot2+mybatisplus+多数据源mysql,现在需要把数据源2更换为pgsql 一、pom文件修改 增加pgsql驱动 <postgresql.version>42.7.1</postgresql.version> <!-- https://mvnrepository.com/artifact/org.postgresql/postgresql --><dependency&…

八数码问题

八数码问题 在3x3的棋盘&#xff0c;摆有八个棋子&#xff0c;每个棋子上标有1至8的某一数字&#xff0c;不同棋子上标的数 字不相同。棋盘上还有一个空格&#xff0c;与空格相邻的棋子可以移到空格中。要求解决的问题 是:给出一个初始状态和一个目标状态&#xff0c;找出一一种…

centos 防火墙 设置 LTS

centos 防火墙 设置 LTS https://blog.csdn.net/m0_58805648/article/details/130671008

详解—数据结构—<常用排序>基本实现和代码分析

目录 一.排序的概念及其运用 1.1排序的概念 1.2排序运用​编辑 1.3 常见的排序算法​编辑 二.常见排序算法的实现 2.1 插入排序 2.1.1基本思想&#xff1a; 2.1.2直接插入排序&#xff1a; 2.1.3 希尔排序( 缩小增量排序 ) 2.2 选择排序 2.2.1基本思想&#xff1a; …

日志记录、跟踪和指标

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版&#xff0c;欢迎购买。点击进入详情 日志记录、跟踪和指标是系统可观察性的三大支柱。 下图显示了它们的定义和典型架构。 记录 日志记录系统中的离散事件。例如&#xff0c;我们可以将传入请求或对…

CentOS 8 上安装 Python 3.10.12

以下是在 CentOS 8 上安装 Python 3.10.12 的全流程&#xff0c;包括下载、编译和安装。请在执行这些步骤之前确保您具有足够的权限。 安装编译依赖项&#xff1a; sudo dnf install -y gcc openssl-devel bzip2-devel libffi-devel zlib-devel readline-devel sqlite-devel下载…

论文阅读——UniRepLKNet

UniRepLKNet: A Universal Perception Large-Kernel ConvNet for Audio, Video, Point Cloud, Time-Series and Image Recognition 当我们将一个33的conv添加到一个小卷积核ConvNet中时&#xff0c;我们预计它会同时产生三种效果——1&#xff09;使感受野更大&#xff0c;2&am…

Linux:多文件编辑

多文件编辑 1.使用vim编辑多个文件 编辑多个文件有两种形式&#xff0c;一种是在进入vim前使用的参数就是多个文件。另一种就是进入vim后再编辑其他的文件。 同时创建两个新文件并编辑 $ vim 1.txt 2.txt默认进入1.txt文件的编辑界面 命令行模式下输入:n编辑2.txt文件&…

从C到C++1

一.思想过渡 前言&#xff1a;明确地说&#xff0c;学了C语言就相当于学了 C 的一半&#xff0c;从C语言转向 C 时&#xff0c;不需要再从头开始&#xff0c;接着C语言往下学就可以&#xff0c;所以我强烈建议先学C语言再学 C。 1.面向过程与面向对象 ​ 从“学院派”的角度来…

Python之自然语言处理库snowNLP

一、介绍 SnowNLP是一个python写的类库&#xff0c;可以方便的处理中文文本内容&#xff0c;是受到了TextBlob的启发而写的&#xff0c;由于现在大部分的自然语言处理库基本都是针对英文的&#xff0c;于是写了一个方便处理中文的类库&#xff0c;并且和TextBlob不同的是&…