/** * Copyright (c) 2011-2020, hubin (jobob@qq.com). *

* Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at *

* http://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.baomidou.mybatisplus.annotation; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** *

* 表字段标识 *

* * @author hubin sjy tantan * @since 2016-09-09 */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.FIELD) public @interface TableField { /** *

* 字段值(驼峰命名方式,该值可无) *

*/ String value() default ""; /** *

* 当该Field为类对象时, 可使用#{对象.属性}来映射到数据表. *

*

* 支持:@TableField(el = "role, jdbcType=BIGINT)
* 支持:@TableField(el = "role, typeHandler=com.baomidou.springcloud.typehandler.PhoneTypeHandler") *

*/ String el() default ""; /** *

* 是否为数据库表字段 *

*

* 默认 true 存在,false 不存在 *

*/ boolean exist() default true; /** *

* 字段 where 实体查询比较条件 *

*

* 默认 `=` 等值 *

*/ String condition() default SqlCondition.EQUAL; /** *

* 字段 update set 部分注入, 该注解优于 el 注解使用 *

*

* 例如:@TableField(.. , update="%s+1") 其中 %s 会填充为字段 * 输出 SQL 为:update 表 set 字段=字段+1 where ... *

*

* 例如:@TableField(.. , update="now()") 使用数据库时间 * 输出 SQL 为:update 表 set 字段=now() where ... *

*/ String update() default ""; /** *

* 字段验证策略 *

*

* 默认 非 null 判断 *

*/ FieldStrategy strategy() default FieldStrategy.NOT_NULL; /** *

* 字段自动填充策略 *

*/ FieldFill fill() default FieldFill.DEFAULT; }