1.Data注解
使用这个注解可以省去实体类当中的get()、set()、toString()方法。
1.使用这个注解需要先加入lombok依赖
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
2.在实体类上面加入@Data注解即可使用
import lombok.Data;
@Data
public class ATest {
private String name;
private String age;
}
使用这个注解的同时还会有两个注解同时使用
@NoArgsConstructor //无参注解
@AllArgsConstructor //全参注解
2.EqualsAndHashCode注解
这个注解的作用就是用来自动实现实体类的equals方法和hashcode方法,我们可以从一个问题中得到我们想要的答案。
问题举例:
1.我们先来定义一个test类,属性值有name和age
import lombok.Data;
@Data
public class Test {
private String name;
private String age;
}
2.然后呢我们再来定义一个testOne类来集成这个test类
import lombok.Data;
@Data
public class TestOne extends Test{
private String sex;
}
3.现在我们创建两个不一样的实体类让他们进行比较看得到后的结果
public static void main(String[] args) {
TestOne testOne = new TestOne();
testOne.setName("张飞");
testOne.setAge("60");
testOne.setSex("男");
TestOne testTwo = new TestOne();
testTwo.setName("李四");
testTwo.setAge("70");
testTwo.setSex("男");
System.out.println("比较的结果是:"+testOne.equals(testTwo));
}
4.我们查看比较后的结果
当我们在实体类上加入注解@EqualsAndHashCode(callSuper = true)
import lombok.Data;
import lombok.EqualsAndHashCode;
@Data
@EqualsAndHashCode(callSuper = true)
public class TestOne extends Test{
private String sex;
}
比较的结果
还有一种解决办法就是直接不使用@Data注解,因为@Data注解是包含这个注解的属性默认是false
@EqualsAndHashCode(callSuper = true) //是用自己的属性和从父类继承的属性来生成hashcode;
@EqualsAndHashCode(callSuper = false) //是只用自己的属性来生成hashcode;
3.TableName注解
这个注解主要用来解决实体类的字段名与数据库中的字段名不匹配的问题(数据库user_addr,字段useraddr未驼峰)
同时使用的注解
// 用来解决数据库中的字段和实体类的字段不匹配问题
@TableField(value = "age")
// 用来解决实体类中有的属性但是数据表中没有的字段
@TableField(exist = false) // 默认为true