MyBatisPlus的@TableField注解基本使用

待我称王封你为后i 2023-09-28 22:24 256阅读 0赞

在这里插入图片描述

前言

在MP中通过@TableField注解可以指定字段的一些属性,常见解决的问题有2种:

1、对象中的属性名和字段名不一致的问题(非驼峰)

2、对象中的属性字段在表中不存在的问题

上述的两种情况,我们接下来一一举例说明

我们最长见的,应该就是下面这种@TableField的使用方式了,是的,没错,就是在实体里面标注这个属性是数据库表里面的某个字段,采用驼峰命名法的方式

@TableField(“user_name”)
private String userName;

前提准备

在正式操作之前,我们需要提前准备一张表

  1. /*
  2. Navicat Premium Data Transfer
  3. Source Server : 本地库
  4. Source Server Type : MySQL
  5. Source Server Version : 80017
  6. Source Host : localhost:3306
  7. Source Schema : mp
  8. Target Server Type : MySQL
  9. Target Server Version : 80017
  10. File Encoding : 65001
  11. Date: 23/08/2022 22:19:37
  12. */
  13. SET NAMES utf8mb4;
  14. SET FOREIGN_KEY_CHECKS = 0;
  15. -- ----------------------------
  16. -- Table structure for tb_user
  17. -- ----------------------------
  18. DROP TABLE IF EXISTS `tb_user`;
  19. CREATE TABLE `tb_user` (
  20. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  21. `user_name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '用户名',
  22. `password` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '密码',
  23. `name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '姓名',
  24. `age` int(11) NULL DEFAULT NULL COMMENT '年龄',
  25. `email` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '邮箱',
  26. PRIMARY KEY (`id`) USING BTREE
  27. ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;
  28. -- ----------------------------
  29. -- Records of tb_user
  30. -- ----------------------------
  31. INSERT INTO `tb_user` VALUES (1, 'zhangsan', '123456', '张三', 18, 'test1@qq.com');
  32. INSERT INTO `tb_user` VALUES (2, 'lisi', '123456', '李四', 20, 'test2@qq.com');
  33. INSERT INTO `tb_user` VALUES (3, 'wangwu', '123456', '王五', 22, 'test3@qq,com');
  34. INSERT INTO `tb_user` VALUES (4, 'zhaoliu', '123456', '赵六', 24, 'test4@qq.com');
  35. SET FOREIGN_KEY_CHECKS = 1;

使用场景1 字段错误

首先我们恶意修改把正确的email 改为mail 让它故意对不上
在这里插入图片描述

此时运行查询 会报错 原因就是因为匹配不到email字段

在这里插入图片描述

然后使用@TableField指定这个mail字段就是数据库里面的email字段

  1. //指定数据库字段名称
  2. @TableField(value = "email")

在这里插入图片描述
然后再次运行查询方法 这次正确了 可见我们的注解起效了
在这里插入图片描述
同理 新增也是一样的 这里我们就直接设置mail的值 还是可以正常插入对应的email的值
在这里插入图片描述
在这里插入图片描述

使用场景2 不存在字段

这时我在是实体里面加入一个表里面不存在的字段

在这里插入图片描述
再次运行报错 找不到该字段

在这里插入图片描述
这时候怎么解决这个问题呢
通过@TableField(exist = false) 指名表里没有这个字段

@TableField(exist = false)
在这里插入图片描述
这个时候再次查询 发现解决了
在这里插入图片描述

使用场景3 不被查询的字段

如果有的字段数据比较隐私 不想被查出来怎么办呢?

我们可以使用下面的这种方式

// 查询的时候不返回该字段的值 默认为true(返回)
@TableField(select=false)
在这里插入图片描述

运行查询 发现password的值已经被隐藏为null

在这里插入图片描述

总结

以上就是MyBatisPlus中的@TableField注解基本使用,后续如果发现更多使用技巧,会及时回来更新

发表评论

表情:
评论列表 (有 0 条评论,256人围观)

还没有评论,来说两句吧...

相关阅读