@TableName
注解
@TableName
注解用于指定 Java 实体类与数据库表的映射关系,尤其在表名与实体类名不一致或不符合命名规范时(驼峰命名)时非常有用。这个注解通常与对象关系映射(ORM)框架一同使用,比如 MyBatis 或 Hibernate。
@TableName(value = "custom_table_name")
public class UserEntity {
// 类的定义
}
在这个例子中,CustomEntity 类将映射到数据库表 "custom_table_name"。
custom_table_name是数据库表的名称。通过在类上添加@TableName注解并指定表名,ORM框架将会将该类与指定的数据库表进行映射。
使用@TableName注解的好处是可以提高代码的可读性和维护性。通过在类上直接指定表名,我们可以清晰地了解该类对应的数据库表是哪个,避免了在代码中散落的表名字符串,提高了代码的可读性和可维护性。
注意
具体的ORM框架可能有自己的注解,例如MyBatis中使用的是@Table注解。因此,在具体使用时,应根据所使用的ORM框架来选择相应的注解。
@TableField
注解
@TableField
注解主要解决两个问题:一是实体类的字段名与数据库中字段名不匹配,二是实体类中存在的属性在表中不存在的问题。
public class User {
@TableField(value = "user_age")//第一种情况
private Integer age;
@TableField(exist = false)//第二张情况
private String additionalField;
// 其他属性和方法
}
-
@TableField(value = "user_age")
: 解决了数据库中字段名为 "user_age",而实体类中的属性为age
的不匹配问题。 -
@TableField(exist = false)
: 表示实体类中的additionalField
属性在数据库表中不存在,这在某些场景下是非常有用的。
@TableId
注解
@TableId 注解用于标识实体类的属性为主键,并可以指定主键的生成策略。这个注解通常与数据库表的主键字段相关联。
通俗来讲,在关系型数据库中,每个表都需要一个主键来唯一标识表中的每一行数据。在ORM框架中,我们可以使用@TableId注解来指定Java类的某个字段作为数据库表的主键。
@TableId(value = "column_name",type = IdType.AUTO)
private Long id;
@TableId(type = IdType.AUTO)
: 表示id
属性是主键,并使用自动增长(AUTO)的方式生成主键值。IdType
提供了多种生成策略,比如全局唯一ID、UUID 等。这里将id
字段作为主键,它对应数据库表中的column_name
列。