【MyBatis-Plus 注解配置】开发中常用注解整理与介绍

不知道朋友们会不会在SpringBoot中集成MyBatis-Plus的时候,总是这个注解那个注解,都不知道哪些是MyBatis-Plus的了,搞得晕乎乎的,所以我整理了一份MyBatis-Plus开发中常用的注解,相信看完你就知道哪些注解是MyBatis-Plus提供的了,以后在开发中就能够更加清晰了

1. @TableName

作用:指定实体类对应的数据库表名。

用法

@TableName("user")
public class User {private Long id;private String name;
}

属性

  • value:表名。
  • schema:数据库 schema 名称。
  • keepGlobalPrefix:是否保留全局表前缀
  • resultMap:自定义结果映射。
  • excludeProperty:查询和操作时排除的字段。
  • autoResultMap:是否启用自动映射结果(解决复杂类型字段问题)。

场景:实体类与数据库表名不一致时使用。

@TableName(value = "sys_user", schema = "public", autoResultMap = true)
public class User {@TableIdprivate Long id;@TableField("nickname")private String name;private Integer age;
}

示例说明

  • 数据库表名为 sys_user,而实体类为 User,通过 @TableName 指定映射关系。
  • 指定了 schema(数据库模式),适用于多模式的数据库。

2. @TableId

作用:指定主键字段,支持主键生成策略。

用法

@TableId(value = "id", type = IdType.AUTO)
private Long id;

属性

  • value:数据库主键列名。
  • type:主键生成策略(IdType.AUTO, IdType.ASSIGN_ID, IdType.NONE, 等)。

3. @TableField

作用:指定实体字段与数据库字段的映射关系。

用法

@TableField("user_name")
private String name;

属性

  • value:数据库字段名。
  • exist:是否存在于表中。
  • condition:自定义查询条件。
  • update:自定义更新逻辑。
  • insertStrategyupdateStrategywhereStrategy
    • 插入/更新/条件时字段的策略控制,支持:
      • DEFAULT:遵循全局配置。
      • NOT_NULL:非空时操作。
      • NOT_EMPTY:非空字符串或非空对象时操作。
      • ALWAYS:总是操作。
  • typeHandler:指定自定义类型处理器

4. @TableLogic

作用:标注逻辑删除字段,MyBatis-Plus 自动处理逻辑删除。

用法

@TableLogic
private Integer deleted;

说明:配合全局配置 logic-delete-valuelogic-not-delete-value 使用。


5. @InterceptorIgnore

作用:忽略某些拦截器的处理,比如分页拦截器。

用法

@InterceptorIgnore(tenantLine = "true", blockAttack = "true")
public List<User> getAllUsers() {return userMapper.selectList(null);
}

说明:忽略租户线(tenantLine)拦截器,查询时不添加租户条件。


6. @EnumValue

作用:标注枚举类的字段,用于数据库值与枚举映射。

用法

public enum Status {@EnumValueACTIVE(1),INACTIVE(0);private final int code;Status(int code) {this.code = code;}
}@TableField("status")
private Status status;

示例说明

  • 数据库中的 status 字段值为 01,自动映射为 Status 枚举。
  • @EnumValue 标注的字段是数据库与枚举之间的映射字段。

7. @Version

作用:标注乐观锁字段。

用法

@Version
private Integer version;

示例说明

  • 插件会拦截更新操作并附加 version 条件:WHERE version = 当前版本
  • 如果版本号不匹配,更新会失败,确保数据一致性。

8. @OrderBy

场景:为查询结果指定默认排序规则。

@OrderBy(asc = true, sort = 1)
private String name;@OrderBy(asc = false, sort = 2)
private Integer age;

示例说明

  • 查询结果会先按 name 升序排序,再按 age 降序排序。
  • 适合需要默认排序的场景,避免每次查询都显式指定排序。

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

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

相关文章

vue 什么时候使用v-if 什么时候使用v-show

在 Vue.js 中&#xff0c;v-if 和 v-show 都是用来控制元素的显示与隐藏的指令&#xff0c;但它们的工作方式和适用场景有所不同。了解两者的区别可以帮助你选择合适的指令来优化应用性能。 v-if 条件渲染&#xff1a;v-if 是“真正的”条件渲染&#xff0c;因为它会根据表达…

MBTiles 及爬取到发布

MBTiles &#xff1a;https://github.com/mapbox/mbtiles-spec/blob/master/1.3/spec.md 1.MBTiles是什么 MBTiles是一个在SQLite 数据库存储瓦片地图数据的标准&#xff0c;该标准的目的是即时传输和使用数据。 作为一个容器格式&#xff0c;MBTiles可以存储任何瓦片数据,…

SpringBoot数据层解决方案

文章目录 1. 数据层解决方案2. 数据源技术 1. 数据层解决方案 现有数据层解决方案技术选型&#xff1a;Druid MyBatis-Plus MySQL 数据源&#xff1a;DruidDataSource持久化技术&#xff1a;MyBatis-Plus / MyBatis数据库&#xff1a;MySQL 下面的研究就分为三个层面进行研…

00_basic_gemm

说明 这里研究的cutlass版本是3.5 gemm讲解 using CutlassGemm cutlass::gemm::device::Gemm<float, // Data-type of A matrixColumnMajor, // Layout of A matrixfloat, // Data-type of B matrixColumnMajor, // Layout of B matrixfloat, // …

永磁同步电机模型预测控制——模型预测研究现状

永磁同步电机 (PMSM) 模型预测控制 (MPC) 研究现状 永磁同步电机 (PMSM) 控制系统是一个强耦合的非线性系统&#xff0c;传统的磁场定向控制 (FOC) 和直接转矩控制 (DTC) 在一些高性能特殊应用场合下难以满足控制需求。为了应对这些挑战&#xff0c;研究人员在 FOC 和 DTC 的基…

Clisoft SOS设置Server和Project

Clisoft SOS设置Server和Project 一、关于SOS Servers、Clients、Projects和Work Areas 以下三个图是官方文档中介绍的三种情况 图1&#xff1a;带有两个客户端的SOS服务器 图2&#xff1a;使用本地缓存服务器 图3&#xff1a;远程设计团队的缓存服务器 因为SOS软件需要…

gaussdb中怎么查询一个表有多少GB

在 GaussDB 中&#xff0c;你可以通过多种方法查询一个表的大小&#xff0c;包括使用系统视图和内置函数。以下是几种常见的方法&#xff1a; 1. 使用 pg_total_relation_size 函数 pg_total_relation_size 函数返回一个表及其所有索引和 TOAST 数据的总大小。 示例查询 SE…

[python3]Excel解析库-calamine,10倍openpyxl性能

calamine 是一个用于读取多种电子表格格式&#xff08;如 Excel、LibreOffice Calc 等&#xff09;的 Python 库。它支持 .xls, .xlsx, .ods 和 .csv 文件格式&#xff0c;提供了简单易用的 API 来加载和处理电子表格数据。calamine 的一大特点是它的轻量级和高效性&#xff0c…

探索 Android Instant Apps:InstantAppInfo 的深入解析与架构设计

探索 Android Instant Apps&#xff1a;InstantAppInfo 的深入解析与架构设计 引言 随着移动应用的快速发展&#xff0c;用户对应用体验的要求越来越高。为了提升用户体验&#xff0c;Google 在 2016 年推出了 Android Instant Apps 这一概念。Instant Apps 允许用户在不安装…

调整Python+Pytest+Allure+Yaml+Pymysql框架中需要执行的用例顺序

当pytest框架中有时时候会因为用例的前后关联关系需要调整用例执行顺序时则可以跟进具体的要求调整pytest.ini配置文件中执行用例文件夹的前后顺序 当如果是需要调整某个文件夹中用例的执行顺序时&#xff0c;则跟进具体的文件调整对应testcases中test_*.py文件中的执行顺序

interval coverage

题意理解&#xff1a;给定一个区间&#xff0c;我们需要把这个区间覆盖掉。问最少需要的区间数目。当然我们会给定 n 个区间选择。假设全选都不能覆盖就输出 − 1 -1 −1 思路分析&#xff1a;我感觉应该是找区间的端点。假设区间的左端点是 s &#xff0c;右端点是 t &#…

【Dify】Dify自定义模型设置 | 对接DMXAPI使用打折 Openai GPT 或 Claude3.5系列模型方法详解

一、Dify & DMXAPI 1、Dify DIFY&#xff08;Do It For You&#xff09;是一种自动化工具或服务&#xff0c;旨在帮助用户简化操作&#xff0c;减少繁琐的手动操作&#xff0c;提升工作效率。通过DIFY&#xff0c;用户能够快速完成任务、获取所需数据&#xff0c;并且可以…

C++编程基础之override关键字

在C中&#xff0c;override关键字用于显式地标识派生类中的成员函数是对基类中虚函数的重写&#xff0c;具有以下重要作用和使用说明&#xff1a; 作用 增强代码可读性&#xff1a;通过使用override关键字&#xff0c;能够清晰地向阅读代码的人表明该函数是有意重写基类中的虚…

Redis数据库笔记—— Hash(哈希)的扩容机制(rehash)

大家好&#xff0c;这里是Good Note&#xff0c;关注 公主号&#xff1a;Goodnote&#xff0c;专栏文章私信限时Free。详细介绍Hash&#xff08;哈希&#xff09;的扩容机制(rehash)、源码、以及扩容和缩容过程。 文章目录 Redis 字典&#xff08;dict&#xff09;结构源码哈希…

Python自学 - 封装与私有化

1 Python自学 - 封装与私有化 1.1 封装的概念 封装是指将数据和方法封装在一起&#xff0c;并且需要通过类的实例来访问&#xff0c;这样就可以确保合适的方法来处理合适的数据&#xff0c;并可以做到只给外界看到想给外界看到的接口&#xff0c;减少数据或方法被滥用的风险。…

网络安全常见的问题

1. 什么是 DDoS 攻击&#xff1f;如何防范&#xff1f; 答&#xff1a;DDoS 攻击是指利用大量的计算机或者其他网络设备&#xff0c;同时向目标网络或者服务器 发送 大量的数据流量&#xff0c;以致其无法正常工作&#xff0c;从而导致网络瘫痪或者服务器宕机的攻击行 为。 …

<rust>在rust中,实现32位浮点数与16进制之间的转换

前言 本文是基于rust&#xff0c;对16进制、32位浮点数之间的互相转换的一个简单示例。 环境配置 系统&#xff1a;windows 平台&#xff1a;visual studio code 语言&#xff1a;rust 库&#xff1a;hex 关键依赖 hex"0.4.3"对于字符串与16进制之间的互相转换&am…

pytest日志显示

在 pytest 中&#xff0c;可以通过 钩子函数 和 配置文件 pytest.ini 配置日志的显示方式&#xff0c;实现对日志的灵活控制。以下是常用实现方式及配置说明。 方式一&#xff1a;使用 conftest.py 钩子函数自定义日志显示 通过 conftest.py 文件中的钩子函数&#xff0c;实现…

支持向量机算法(一):像讲故事一样讲明白它的原理及实现奥秘

1、支持向量机算法介绍 支持向量机&#xff08;Support Vector Machine&#xff0c;SVM&#xff09;是一种基于统计学习理论的模式识别方法&#xff0c; 属于有监督学习模型&#xff0c;主要用于解决数据分类问题。SVM将每个样本数据表示为空间中的点&#xff0c;使不同类别的…

ES中的仓库和快照

文章目录 简介仓库&#xff08;Repository&#xff09;快照&#xff08;Snapshot&#xff09;常用命令记录 简介 在Elasticsearch&#xff08;简称ES&#xff09;中&#xff0c;仓库&#xff08;repository&#xff09;和快照&#xff08;snapshot&#xff09;是两种重要的备份…