MyBatis-Plus中@TableField和@TableId说明

 更新时间:2026年01月12日 08:44:12   作者:strggle_bin  
文章详细介绍了Mybatis-plus中常用的注解及其用途,包括@TableField、@TableId等,通过这些注解可以解决字段不一致、字段不显示、忽略字段以及主键查询等问题,从而提高开发效率和数据安全性

一、@TableField(value = “表字段”)

如果表的字段与pojo类的属性值对应不上,就像表字段为user_name,但是属性的为uName时,在查询所有中就会报错,找不到表的字段信息。

java.sql.SQLSyntaxErrorException: Unknown column ‘u_name’ in ‘field list’

就是表的字段和User类没有对应上。

这里就需要加入该注解@TableField(value = “user_name”),解决字段不一致问题(value写表字段名),使得一一对应起来。

    @TableField(value = "user_name")
    private String uName;

注:

但如果表字段user_name。定义的userName。

驼峰命名会自动识别。不写注解也可以)

再次运行即可解决该问题 如图所示:

二、@TableField(select = false)

这是用来解决如果用户名密码不想显示时可以在属性上添加该字段,sql语句就不会去查询该字段。

这样在查询时密码字段会变成null输出,保证安全性。

 	//查询不显示用户密码
    @TableField(select = false)
    private String userPassword;

三、@TableField(exist = false)

在添加中,如果User类下的属性数据库字段没有,再添加时还会给这个属性赋值,然后发送到mapper执行插入数据操作时就会报错。

java.sql.SQLSyntaxErrorException: Unknown column ‘hobby’ in ‘field list’

Mybatis-plus忽略表中映射的字段:

Mybatis-plus使用entity和数据库进行关联映射,有时候可能有些字段,在当前表中不存在,但是操作的时候,又需要进行使用,所以有时候就需要进行忽略。

具体如何忽略如下:

  • @TableField(exist = false):表示该属性不是表中字段,但又是必须使用的。
  • @TableField(exist = true):表示该属性是表中字段。

执行下面的测试方法进行测试:

	//测试添加方法
    @Test
    public void testInsert(){
        User user=new User();
        user.setUserName("哈哈111");
        user.setUserEmail("12433");
        user.setUserRole("ADMIN");
        user.setUserStatus("0");
        user.setUserPassword("12344");
 
		// 表中没有字段
        user.setHobby("足球");
        //受影响的行数  count
        int count = userMapper.insert(user);
        if(count>0){//添加成功
            //输出所有数据
            testSelectList();
        }else {//添加失败
            System.out.println("添加失败~");
        }
    }

解决该方法:

就要使用 @TableField(exist = false)注解,表示数据表中没有该字段,添加时生成sql代码就会知道。

//数据库中没有该字段时需要添加注解
@TableField(exist = false)
private String hobby;

四、@TableId(type = IdType.AUTO)补充

这个是通过id查询时,如果不在id主键属性上添加该注解的话,就会报以下错误

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): cn.imust.mp.mapper.UserMapper.selectById

这就表名虽然有属性和表字段也对应,但是在通过id查询时MP不知道这个是主键,所以无法执行该方法,解决方法就是在属性上添加@TableId(type = IdType.AUTO),type等于的值有很多,一般主键都是用这个。

	@TableId(type = IdType.AUTO)
    private Integer userId;

查看运行效果 如图所示:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot项目依赖和配置最新示例讲解

    SpringBoot项目依赖和配置最新示例讲解

    这篇文章主要介绍了SpringBoot项目依赖和配置,这里主要是搭建项目常用到的maven依赖以及搭建项目会需要用到的一些配置文件,本文通过示例代码给大家详细讲解,需要的朋友可以参考下
    2022-11-11
  • Java的反射机制之类加载详解

    Java的反射机制之类加载详解

    这篇文章主要介绍了Java的反射机制之类加载详解,反射机制是java实现动态语言的关键,也就是通过反射实现类动态加载,静态加载是指在编译时期确定要加载的类的类型,即通过class关键字和类名来获取对应类的类型,需要的朋友可以参考下
    2023-09-09
  • RocketMQ消息生产者是如何选择Broker示例详解

    RocketMQ消息生产者是如何选择Broker示例详解

    这篇文章主要为大家介绍了RocketMQ消息生产者是如何选择Broker示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • java agent使用全解析

    java agent使用全解析

    这篇文章主要介绍了javaagent的相关资料,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解下
    2020-07-07
  • java 记录一个子串在整串中出现的次数实例

    java 记录一个子串在整串中出现的次数实例

    今天小编就为大家分享一篇java 记录一个子串在整串中出现的次数实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • SpringBoot如何使用@Cacheable进行缓存与取值

    SpringBoot如何使用@Cacheable进行缓存与取值

    这篇文章主要介绍了SpringBoot如何使用@Cacheable进行缓存与取值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • SpringBoot+Mybatis使用Enum枚举类型总是报错No enum constant XX问题

    SpringBoot+Mybatis使用Enum枚举类型总是报错No enum constant&n

    这篇文章主要介绍了SpringBoot+Mybatis使用Enum枚举类型总是报错No enum constant XX问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • SpringBoot集成flink全过程

    SpringBoot集成flink全过程

    文章介绍了Flink作为批处理和流处理结合的统一计算框架,特别是其强大的流处理能力,文章还详细描述了如何在本地和集群环境中搭建Flink,并通过Netcat工具生成一个无界流测试,文章最后提供了启动socket流的步骤和示例代码,希望对读者有所帮助
    2025-01-01
  • Mybatis3 if判断字符串变态写法

    Mybatis3 if判断字符串变态写法

    这篇文章主要介绍了Mybatis3 if判断字符串变态的写法,非常不错,具有参考借鉴价值,需要的朋友参考下
    2017-01-01
  • spring security动态配置url权限的2种实现方法

    spring security动态配置url权限的2种实现方法

    对于使用spring security来说,存在一种需求,就是动态去配置url的权限,即在运行时去配置url对应的访问角色。下面这篇文章主要给大家介绍了关于spring security动态配置url权限的2种实现方法,需要的朋友可以参考下
    2018-06-06

最新评论