/** * 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")
*
* 是否为数据库表字段 *
** 默认 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; }