码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 5、Mybatis-Plus 常用注解


    第一篇:1、Mybatis-Plus 创建SpringBoot项目
    第二篇:2、Mybatis-Plus 测试增、删、改、查
    第三篇:3、Mybatis-Plus 自定义sql语句
    第四篇:4、Mybatis-Plus 通用service的操作

    文章目录

    • 1、表名(如果实体类和数据库中的表名不一致,会出现以下问题)
    • 2、注解解决数据库字段和实体类字段问题,主键生成策略
      • 2.1、直接在实体类上进行注解
      • 2.2、全局配置,在yml文件中
      • 2.3、数据库的主键和实体类的主键保持一致。但是不是id的情况下、不进行注解配置。会出现的问题?
      • 2.4、数据库的主键和实体类的主键不一致
      • 2.5、如果自己设定了id的值 不会使用自增策略的值
    • 3、当数据库中表的字段和实体类的字段不一一对应时
      • 3.1 数据库字段
      • 3.2 实体类字段
      • 3.3 出现的错误
      • 3.4、使用@TableField("username") 指定对应的字段名
      • 3.5 测试结果
    • 4、逻辑删除
      • 4.1、在数据库表中新添加一个字段表示删除状态
      • 4.2、在实体类属性中添加,同时注解@TableLogic
      • 4.3 、测试结果

    1、表名(如果实体类和数据库中的表名不一致,会出现以下问题)

    在这里插入图片描述
    解决方法:在实体类中添加注解

    @Data
    //设置实体类所对应的表名:数据库中对应实体类的表名
    @TableName("t_user")
    public class User {
    
        private Long id;
    
        private String name;
    
        private Integer age;
    
        private String email;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    再次执行代码

    在这里插入图片描述
    mybatis-plus根据哪里操作数据库中的表?
    在这里插入图片描述


    2、注解解决数据库字段和实体类字段问题,主键生成策略

    2.1、直接在实体类上进行注解

    package com.zyz.mybatisplus.pojo;
    
    import com.baomidou.mybatisplus.annotation.IdType;
    import com.baomidou.mybatisplus.annotation.TableId;
    import com.baomidou.mybatisplus.annotation.TableName;
    import lombok.Data;
    
    @Data
    //设置实体类所对应的表名:数据库中对应实体类的表名
    //@TableName("t_user")
    public class User {
    
        //如果设置了主键的id,则不会使用自增id
    
        /**
         * 1、mybatis-plus会默认id为主键。如果数据库中的表主键和实体类的主键不是id(默认两个字段一致)。
         * 需要在实体类字段上添加@TableId属性。
         *
         *  2、如果实体类字段的主键和数据库中表的主键不一致。@TableId注解的value属性用于指定主键的字段
         */
        //将属性对应的字段指定为主键
    
    //    @TableId
    //    private Long id;
    
                //如果只有一个属性,value可以省略 @TableId("uid")
    //    @TableId(value = "uid")
    //    private Long id;
    
        /**
         * type指定主键生成的策略。默认采用雪花算法
         * 采用数据库的自增策略:注意:数据库中的该字段设置了id自增,否则无效
         */
    
        @TableId(value = "uid",type = IdType.AUTO)
        private Long id;
    
        private String name;
    
        private Integer age;
    
        private String email;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    2.2、全局配置,在yml文件中

    #设置mybatis-plus的全局配置:
      global-config:
        db-config:
          #设置实体类对应数据库中表的统一前缀
          table-prefix: t_
          #配置mybatis-plus的主键策略
          id-type: auto
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.3、数据库的主键和实体类的主键保持一致。但是不是id的情况下、不进行注解配置。会出现的问题?

    在这里插入图片描述

    2.4、数据库的主键和实体类的主键不一致

    在这里插入图片描述

    2.5、如果自己设定了id的值 不会使用自增策略的值

    3、当数据库中表的字段和实体类的字段不一一对应时

    3.1 数据库字段

    在这里插入图片描述

    3.2 实体类字段

    在这里插入图片描述

    3.3 出现的错误

    在这里插入图片描述

    3.4、使用@TableField(“username”) 指定对应的字段名

    在这里插入图片描述

    3.5 测试结果

    在这里插入图片描述

    4、逻辑删除

    4.1、在数据库表中新添加一个字段表示删除状态

    4.2、在实体类属性中添加,同时注解@TableLogic

    在这里插入图片描述

    4.3 、测试结果

    在这里插入图片描述


  • 相关阅读:
    [postgres]配置主从异步流复制
    【21天打卡】前端攻城狮重学算法之-直接选择排序
    .NET 云原生架构师训练营(权限系统 代码实现 ActionAccess)--学习笔记
    JVM、JRE、JDK
    linux环境搭建mysql5.7总结
    JavaScript 防抖与节流
    #include “ascii_font.c“ 引入源文件,Keil5为什么没有提示重复定义错误,详解!!!
    9.基于粤嵌gec6818开发板小游戏2048的算法实现
    HTML中的文本标签:微观排版的艺术
    构建你的Conda包:使用conda skeleton命令打造包的骨架
  • 原文地址:https://blog.csdn.net/weixin_43304253/article/details/126823280
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号