首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

JPA惯用注解

2012-12-14 
JPA常用注解@Entity作用:设置一个类为实体类@Entitypublic class User {}?@Table作用:设置实体类对应的表,

JPA常用注解

@Entity
作用:设置一个类为实体类

@Entitypublic class User {}

?

@Table
作用:设置实体类对应的表,常与@Entity一起使用
参数:name制定表名,不写的话,为实体类的类名

@Entity@Table(name = "tbl_user")public class User {}

@Id
作用:设置对象标识符

@Idprivate 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;

@Column
作用:设置列

?

参数:
name:指定列名
unique:指定唯一约束
nullable:指定是否允许为空
length:长度

?

@Column(name = "user_name", length = 255, nullable = true, unique = true)private String name;

设置默认值:

@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;

分享到: