MybatisPlus 使用教程

MyBatisPlus使用教程

文章目录

  • MyBatisPlus使用教程
    • 1、使用方式
      • 1.1 引入依赖
      • 1.2 构建mapper接口
    • 2、常用注解
      • 2.1 @TableName
      • 2.2 @TableId
      • 2.3 @TableField

MyBatisPlus顾名思义便是对MyBatis的加强版,但两者本身并不冲突(只做增强不做改变):

在这里插入图片描述

引入它并不会对原有工程产生影响,启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作!!

1、使用方式

它的使用方式也很简单:

1.1 引入依赖

<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version>
</dependency>

注:这里的依赖引入之后就不需要引入mybatis的依赖了

1.2 构建mapper接口

public interface UserMapper extends BaseMapper<User> {}

注:这里需要让mapper接口继承BaseMapper<>,且泛型要写上实体类

实体类代码(可自行编写):

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import com.itheima.mp.enums.UserStatus;
import lombok.Data;import java.time.LocalDateTime;@Data
public class User {/*** 用户id*/private Long id;/*** 用户名*/private String username;/*** 密码*/private String password;/*** 注册手机号*/private String phone;/*** 详细信息*/private UserInfo info;/*** 使用状态(1正常 2冻结)*/private UserStatus status;/*** 账户余额*/private Integer balance;/*** 创建时间*/private LocalDateTime createTime;/*** 更新时间*/private LocalDateTime updateTime;
}

数据库(可自行搭建):

在这里插入图片描述

测试一下:

@SpringBootTest
class UserMapperTest {@Autowiredprivate UserMapper userMapper;@Testvoid testInsert() {User user = new User();user.setId(5L); // 可见这里在未配置注解或xml的情况下也可直接调用方法user.setUsername("XiaoMi"); user.setPassword("123");user.setPhone("10086");user.setBalance(200);user.setInfo(UserInfo.of(24, "英文老师", "female"));user.setCreateTime(LocalDateTime.now());user.setUpdateTime(LocalDateTime.now());userMapper.insert(user);}@Testvoid testSelectById() {User user = userMapper.selectById(5L);System.out.println("user = " + user);}}

在这里插入图片描述

在这里插入图片描述

按上述步骤来即可执行成功!!相较于mybatis需要编写注解或xml,mybatisplus在接口继承之后就能够直接调用相关的方法来进行CURD,节省了许多重复工作,这对于快速开发来说很有帮助!!

2、常用注解

MyBatisPlus是通过扫描实体类(即BaseMaper<>泛型),并基于反射获取实体类信息来作为数据库信息,如果直接使用该实体类的话有几个前提条件:

  • 默认以类名驼峰转下划线作为表名
  • 默认把名为id的字段作为主键
  • 默认把变量名按驼峰方式转下划线作为表的字段名

若上述条件有差异,则需要通过注解的方式来调整:

2.1 @TableName

用于指定表名称及全局配置

类名与表名不一致(驼峰转换后不一致)会报错,需要通过@TableName注解进行指定表名:

@Data
@TableName("tb_user")
public class User {
}

在这里插入图片描述

2.2 @TableId

指定Id字段及其相关配置

对于Id字段,它一般用于描述主键,同时它也有一些属性需要添加,如自增长,可以通过@TableId进行指定:

  • IdType.AUTO:数据库自增长
  • IdType.INPUT:通过set方法自行输入
  • IdType.ASSIGN:分配ID
@TableId(value="id", type = IdType.AUTO)
private Long id;

2.3 @TableField

指定普通字段及其相关配置

@TableField一般用于以下场景:

  • 成员变量与数据库字段名不一致
  • 成员变量以is开头,且是布尔值
  • 成员变量与数据库关键字冲突,如order
  • 成员变量不是数据库字段
@TableField("username")
private String name; // 名字与数据库表中字段不同@TableField(exist = false)
private String address; // 数据库表中不存在

在这里插入图片描述

以上便是MyBatisPlus的基本使用教程了!!对于MyBatisPlus的来说,它更适合于单表操作,如果需要对多表进行复杂操作则需使用MyBatis!!

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

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

相关文章

老年实训室的技能大赛介绍

在当今老龄化社会的背景下&#xff0c;老年护理和服务的质量愈发受到关注。为了提升相关人员的专业技能和服务水平&#xff0c;老年实训室的技能大赛应运而生。 老年实训室的技能大赛通常涵盖了多个方面的考核内容&#xff0c;旨在全面检验参赛者在老年护理与服务领域的综合能力…

ES6 Iterator 与 for...of 循环(五)

Iterator 特性&#xff1a; 统一的接口&#xff1a;无论是数组、字符串还是自定义对象&#xff0c;只要它们有默认的迭代器&#xff0c;就可以使用 for…of 循环进行遍历。可迭代对象&#xff1a;具有 [Symbol.iterator] 属性的对象被认为是可迭代的。[Symbol.iterator] 是一个…

FastAPI 学习之路(三十九)对开发接口进行测试

概况 对于开发好的接口需要进行测试之后才能发布。当我们在开发的时候&#xff0c;没有提前测试&#xff0c;我们也要对我们自己的接口进行测试&#xff0c;那么FastApi自身也带有针对开发的接口进行测试的功能。我们看下FastApi官方给我们提供了什么样的支持。 接口还是基于…

笔记本硬盘数据恢复的6种方法!简单易懂

可以从笔记本电脑硬盘恢复已删除的数据吗&#xff1f; “我不小心删除了笔记本电脑硬盘上的重要数据。请问我可以在笔记本电脑硬盘上恢复已删除的数据吗&#xff1f;如果可以&#xff0c;我应该怎么做才能恢复数据呢&#xff1f;” 很多笔记本电脑用户可能会不小心地从电脑中…

线程冲突案例演示

我们以银行取款经典案例来演示线程冲突现象。 银行取款的基本流程可以分为如下几个步骤。 &#xff08;1&#xff09;用户输入账户、密码&#xff0c;系统判断用户的账户、密码是否匹配。 &#xff08;2&#xff09;用户输入取款金额。 &#xff08;3&#xff09;系统判断账…

JavaSE 面向对象程序设计进阶 IO 练习读取多个对象

练习读取多个对象 用序列化流将对象写入文件 import java.io.*; import java.nio.charset.Charset;public class Main {public static void main(String[] args) throws IOException, ClassNotFoundException {//序列化多个对象Person p1new Person("多多", 男,20)…

梧桐数据库:数据库产品中的自然语言语义分析技术

数据库产品中的自然语言语义分析技术是一项重要的自然语言处理技术&#xff0c;它涉及对自然语言文本进行深度理解和分析&#xff0c;从而识别文本中的实体、关系、情感等语义信息&#xff0c;并将这些信息转化为计算机可以理解和处理的形式。 一、自然语言语义分析技术的定义…

蓝牙 - Terminal I/O Service Specification

1, Introduction 1.1, Scope 通过该服务&#xff0c;终端 I/O 客户端设备可连接终端 I/O 服务器设备并与之交互&#xff0c;从而实现串行数据和 GPIO 状态信息的双向交流。 终端 I/O 服务公开本地 UART 数据和本地 GPIO 状态变化&#xff0c;并允许 GATT 客户向 GATT 服务器传…

Elasticsearch 基础查询语句汇总

Elasticsearch 基础查询语句汇总 准备条件指定id查询一指定id查询二指定多个id查询区间查询模糊查询多字段查询分页查询查询总数量 准备条件 以下查询操作都基于索引crm_clue来操作&#xff0c;索引已经建过了&#xff0c;本文主要讲Elasticsearch查询语句&#xff0c;下面开始…

DP学习——设计模式代码采集

学而时习之&#xff0c;温故而知新。 c&#xff0b;&#xff0b;代码 1111https://blog.csdn.net/xushuilong/article/details/106962825 22222

电商之订单价税拆分实现方案

文章目录 案例数据实现思路1、计算出平均金额2、计算每个商品的金额 实现方案1、订单 order 实体2、订单明细 orderDetail 实体3、实现类4、测试启动5、实现结果 在做电商项目的时候&#xff0c;会遇到要对订单明细进行纳税金额拆分&#xff0c;即将税额拆分到每个商品上&#…

Android 自定义Edittext 和TextView 提示文字和填入内容不同的粗细组件

近期项目中又EditText 以及TextView 这两个组件需要用到提示文字 以及 填入文字要保持不同的粗细程度,所以记录一下 首先 是EditText 组件的自定义 BLEditText 继承的这个组件是一个三方的组件,可以在很大程度上减少drawable的编写,有兴趣的可以去相关的Git去看一下 点击查看,…

[leetcode]maximum-binary-tree 最大二叉树

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {return construct(nums, 0, nums.size() - 1);}TreeNode* construct(const vector<int>& nums, int left, int right) {if …

人工智能算法工程师(中级)课程4-sklearn机器学习之回归问题与代码详解

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能算法工程师(中级)课程4-sklearn机器学习之回归问题与代码详解。回归分析是统计学和机器学习中的一种重要方法&#xff0c;用于研究因变量和自变量之间的关系。在机器学习中&#xff0c;回归算法被广泛应用于…

软件开发23种设计模式

一、设计模式分类 软件开发的23种模式&#xff0c;主要分类有创建型模式&#xff0c;结构型模式&#xff0c;行为型模式三种&#xff0c;相关分类如下&#xff1a; 设计模式是一种面向对象编程的思想&#xff0c;它是由Gamma等人在《设计模式&#xff1a;可复用面向对象软件的…

中新青年领导人交流营走进李良济,零距离感受中医药文化的魅力

7月8日晚&#xff0c;2024中新青年领导人交流营在苏州正式启动。该交流营主题为“青年创业和可持续发展”&#xff0c;由中华全国青年联合会、新加坡全国青年理事会主办&#xff0c;江苏省、北京市青年联合会与苏州市人民政府承办&#xff0c;苏州市青年联合会与苏州工业园区管…

k8s核心操作_Ingress统一网关入口_域名访问配置_ingress域名转发规则配置_根据域名访问不同服务---分布式云原生部署架构搭建026

上一节我们已经把 ingress 安装好了可以看到 kubectl get svc -A 可以看到 出现了ingress-nginx 的service,在ingre-nginx这个命名空间中,有两个,一个是 ingress-nginx-controller 开了两个一个是对应http,一个对应https 一个是 ingress-nginx-controller-admission 对…

unordered_map和set

前言&#xff1a;本篇文章继续分享新的容器unordered_map和set。前边我们分享过map和set&#xff0c;其底层为红黑树&#xff0c;而unordered_map和set的底层则为哈希表&#xff0c;因此在unordered_map和set的实现中&#xff0c;我们可以效仿许多在map和set的中就分享过的一些…

银河麒麟(Kylin)KYSEC使用

1.推荐使用方法 *.临时禁用指令: setstatus disable--禁用 注&#xff1a;执行reboot后系统会自动启动 2.选用指令&#xff1a; *.永久禁用指令&#xff1a; setstatus disable -p *.重启后,KYSEC还是处理关闭关状态。 *.使用如下指令启用&#xff1a;setstatus enable …

详细介绍一下TypeScript

TypeScript (TS) 是一种由微软开发和维护的开源编程语言。它是 JavaScript 的一个超集&#xff0c;意味着所有的 JavaScript 代码都可以在 TypeScript 中无需修改地运行。TypeScript 添加了可选的静态类型系统&#xff0c;这使得开发者能够在开发大型应用程序时更早地检测和修复…