mybatis plus @TableField(exist = false)
时间: 2023-12-14 12:42:45 浏览: 132
@TableField(exist = false) 是 MyBatis-Plus 的注解之一,用于标识实体类中的字段在数据库表中不存在。当一个字段使用该注解标记为 exist = false 后,MyBatis-Plus 将不会将该字段映射到数据库表中,即不会自动生成对应的数据库列。
这个注解通常用于实体类中的一些临时属性或计算属性,这些属性在数据库中没有对应的列,但在业务逻辑中需要使用。通过添加 @TableField(exist = false) 注解,可以告诉 MyBatis-Plus 不要将这些字段映射到数据库表中,从而避免不必要的错误或冗余。
需要注意的是,@TableField(exist = false) 注解只能用于实体类的字段上,不能用于类或方法上。
相关问题
@TableField注解的作用,@TableField(exist = false)是什么意思
@TableField注解是MyBatis-Plus框架中的一个注解,用于标识实体类中的字段与数据库表中的字段的映射关系。它可以用于指定字段名、是否为数据库表字段以及字段的策略等。
具体来说,@TableField注解有以下作用:
1. 标识实体类中的字段与数据库表中的字段的映射关系。
2. 可以通过name属性指定字段在数据库表中的名称,如果不指定,则默认使用字段名作为数据库表中的列名。
3. 可以通过exist属性指定该字段是否为数据库表中的字段,默认为true,表示是数据库表字段;设置为false时,表示该字段不是数据库表中的字段。
4. 可以通过strategy属性指定字段的填充策略,如自动填充、插入时填充、更新时填充等。
对于@TableField(exist = false),它的意思是该字段不是数据库表中的字段。在使用MyBatis-Plus进行数据库操作时,会忽略该字段,不会将其作为查询条件或者更新的字段。
@TableField(exist = false
@TableField(exist = false)注解是用来解决表中表的问题的。它可以在加载bean属性时使用,表示当前属性不是数据库的字段,但在项目中必须使用。这样可以将一个数据表当作一个字段来输出,实现表中表数据的输出。当在新增等使用bean的时候,mybatis-plus会忽略这个注解,不会报错。
举个例子,比如在一个实体类中,使用了@TableField(exist = false)注解来定义一些List类型的属性,如:
@TableField(exist = false) private List<CtnOrderBoxInfo> boxInfos;
@TableField(exist = false) private List<CtnOrderFee> fees;
@TableField(exist = false) private List<CtnOrderAttachInfo> orderAttachInfos;
@TableField(exist = false) private List<CtnRemarksHistory> remarksHistories;
这样就可以将boxInfos、fees、orderAttachInfos和remarksHistories当作一个字段来输出,而不是作为数据库的字段。
阅读全文