@Entity
作用:设置一个类为实体类
- @Entity
- public class User {
- }
@Entity
public class User {
}
@Table
作用:设置实体类对应的表,常与@Entity一起使用
参数:name制定表名,不写的话,为实体类的类名
- @Entity
- @Table(name = "tbl_user")
- public class User {
- }
@Entity
@Table(name = "tbl_user")
public class User {
}
@Id
作用:设置对象标识符
- @Id
- private Integer id;
@Id
private Integer id;
@GeneratedValue
作用:设置标识符的生成策略,常与@Id一起使用
参数:strategy指定具体的生成策略
方式一:@GeneratedValue(strategy=GenerationType.AUTO) 也是默认策略, 即写成@GeneratedValue也可。
类似于hibernate的native策略,生成方式取决于底层的数据库。
方式二:@GeneratedValue(strategy = GenerationType.IDENTITY)指定“自动增长”策略,适用于MySQL。
方式三:@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq_tbl_user")指定“序列”策略,使用于Oracle。
其中generator表示生成器的名字。
而且还要指定@SequenceGenerator(name = "seq_tbl_user", sequenceName = "seq_tbl_user", allocationSize = 1)注解配合使用
其中name指定生成器的名字(与generator的值一样),sequenceName指定数据库中定义序列的名字,allocationSize指定序列每次增长1
方式四:若不指定@GeneratedValue注解,则要手动提供Id值。user.setId();
- @Id
- /** 自增 用于MySQL */
- @GeneratedValue(strategy = GenerationType.IDENTITY)
- /** 序列 用于Oracle */
- @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq_tbl_user")
- @SequenceGenerator(name = "seq_tbl_user", sequenceName = "seq_tbl_user", allocationSize = 1)
- /** 默认的 等同于@GeneratedValue */
- @GeneratedValue(strategy = GenerationType.AUTO)
- private Integer id;
@Id
/** 自增 用于MySQL */
@GeneratedValue(strategy = GenerationType.IDENTITY)
/** 序列 用于Oracle */
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq_tbl_user")
@SequenceGenerator(name = "seq_tbl_user", sequenceName = "seq_tbl_user", allocationSize = 1)
/** 默认的 等同于@GeneratedValue */
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;
@Column
作用:设置列
参数:
name:指定列名
unique:指定唯一约束
nullable:指定是否允许为空
length:长度
- @Column(name = "user_name", length = 255, nullable = true, unique = true)
- private String name;
@Column(name = "user_name", length = 255, nullable = true, unique = true)
private String name;
设置默认值:
- @Column(name = "user_name")
- private String name = "monday";
@Column(name = "user_name")
private String name = "monday";
注意:若不写@Column注解,则一切使用@Column注解的默认值。
@Temporal
作用:设置日期时间
方式一:@Temporal(TemporalType.DATE)映射为日期 // birthday date (只有日期)
方式二:@Temporal(TemporalType.TIME)映射为日期 // birthday time (是有时间)
方式三:@Temporal(TemporalType.TIMESTAMP)映射为日期 //birthday datetime (日期+时间)
- @Temporal(TemporalType.DATE)
- private Date birthday;
@Temporal(TemporalType.DATE)
private Date birthday;
@Lob
作用:设置大数据类型
方式一:
- @Lob
- private String text; //text longtext
@Lob
private String text; //text longtext
方式二:
- @Lob
- private byte[] image; // image longblob
@Lob
private byte[] image; // image longblob
@Enumerated
作用:设置枚举类型
方式一:
- /** 保存字符串到数据库 */
- @Enumerated(EnumType.STRING)
- private Role role;
/** 保存字符串到数据库 */
@Enumerated(EnumType.STRING)
private Role role;
方式二:
- /** 保存整数到数据库 */
- @Enumerated(EnumType.ORDINAL)
- private Role role;
/** 保存整数到数据库 */
@Enumerated(EnumType.ORDINAL)
private Role role;
上面定义的枚举:Role
- /** 角色 */
- public enum Role {
- 游客, 会员, 管理员
- }
/** 角色 */
public enum Role {
游客, 会员, 管理员
}
使用:
- User user = new User();
- user.setRole(Role.管理员);
User user = new User();
user.setRole(Role.管理员);
@Transient
作用:修饰的字段不会被持久化
- @Transient
- private String temp;
@Transient
private String temp;
这样也可以:
- private transient String temp;
private transient String temp;
以上都这都是比较常用的。