MybatisPlus——常用注解

MybatisPlus------常用注解

MybatisPlus通过扫描实体类,并基于反射获取实体类信息作为数据库表信息

BaseMapper后的指向的是User实体类

java 复制代码
package com.example.mybatisplus02.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.mybatisplus02.entity.User;

public interface UserMapper extends BaseMapper<User> {
}

对应到表的表的结构遵循一下规则:

  1. 类名驼峰转下划线座位表名
  2. 名为id的字段作为主键
  3. 变量名驼峰转下划线作为表的字段名
java 复制代码
package com.example.mybatisplus02.entity;

import lombok.Data;

@Data
public class User {
    private Integer userId;
    private String userName;
    private String password;
}

MybatisPlus------常用注解

  • @TableName:用来指定表名
  • @TableId:用来指定表中的主键字段信息
  • @TableField:用来指定表中普通字段信息

1、如果表的名称与实体类的名称不符,需要用到@TableName注解

java 复制代码
@Data
@TableName("t_user")
public class User {
    private Integer id;
    private String userName;
    private String password;
}

与数据库中的t_user表对应

2、定义主键id,在实体类中建议都要用注解来定义上id,防止找不到id而报错

value:表示要指向的数据库的表名称

type:IdType:

AUTO:数据库自增长

INPUT:通过set方法自行输入

ASSIGN_ID:接口IdentifierGenerator的方法nextId来生成ID

默认实现类为:DefaultIdentifierGenerator雪花算法

java 复制代码
@Data
@TableName("t_user")
public class User {
    @TableId(value = "user_id" ,type = IdType.AUTO)
    private Integer id;
    private String userName;
    private String password;
}

3、 如果表的字段与实体类的中不符,需要用到@TableField注解

使用@TableField注解的常见场景

  • 成员变量名与数据库字段名不一致
  • 成员变量名以is开头,而且是布尔值
  • 成员变量名与数据库关键字冲突
  • 成员变量不是数据库字段(@TableField(exist = fales) )
java 复制代码
@Data
@TableName("t_user")
public class User {
    @TableId(value = "user_id" ,type = IdType.AUTO)
    private Integer id;
    private String userName;
    @TableField(value = "password")
    private String passWord;
}
相关推荐
二哈赛车手4 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~5 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8295 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
未若君雅裁6 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记7 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI7 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
辰海Coding8 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
小小编程路8 小时前
C++ 多线程与并发
java·jvm·c++
AI视觉网奇8 小时前
linux 检索库 判断库是否支持
java·linux·服务器