1、@Entity(name=””)
必选:只能标注在实体的class定义处,注释声明该类为持久类;
name:可选,重定向实体名;
2、@Table(name=”“,catalog=”“,schema=”“)
可选:通常和@Entity配合使用,标注在@Entity下,表示实体对应的数据库表的信息;
name:可选,表示表的名称.默认实体名称;
catalog:可选,表示Catalog名称,默认为Catalog(“”);
schema:可选,表示Schema名称,默认为Schema(“”);
3、@id
必须:表的主键,一个实体类只能含有一个@id注解;
4、@GeneratedValue(strategy=GenerationType,generator=”“)
可选:主键的生成策略;
strategy:主键生成策略AUTO,INDENTITY,SEQUENCE 和 TABLE 4种。分别表示让ORM框架自动选择,根据数据库的Identity字段生成,根据数据库表的Sequence字段生成,根据一个额外的表生成主键。默认为AUTO;
generator:表示主键生成器的名称,这个属性通常和ORM框架相关。例如,Hibernate可以指定uuid等主键生成方式。
5、@Column
可选:描述了数据库表中该字段的详细定义;
name:字段的名称,默认属性名;
nullable:否允许为null,默认为true;
unique:是否是唯一标识,默认为false;
length:字段的大小,仅对String类型的字段有效;
insertable:执行插入操作时,该字段是否应出现INSETRT语句中,默认为true;
updateable:执行更新操作时,该字段是否应该出现在UPDATE语句中,默认为true;
columnDefinition:字段在数据库中的实际类型。例如:String的默认映射类型为VARCHAR,如果要将String类型映射到特定数据库的BLOB或TEXT字段类型,该属性非常有用;
@Entity // 表示该类是个实体类
@Table(name = "UserInfo") // 指定数据库对应的表明,解决类名和表明不一致
public class UserInfo {
private int id;
private Date createtime;
private String username;
private String passwd;
@Id // 指定该属性为主键
@GeneratedValue(strategy = GenerationType.IDENTITY) // 主键生成策略,根据连接的数据库自主选择。表示ID自增
@Column(name = "id") // 解决属性名和字段名不对应
public int getId() {
return this.id;
}
// @Temporal(TemporalType.DATE) 限制时间格式:只记录日期不记录时间。默认是时间日期都记录
public Date getCreatetime() {
return this.createtime;
}
@Column(length = 32) // 限制字符串长度
public String getUsername() {
return this.username;
}
public String getPasswd() {
return this.passwd;
}
public void setId(int id) {
this.id = id;
}
public void setCreatetime(Date createtime) {
this.createtime = createtime;
}
public void setUsername(String username) {
this.username = username;
}
public void setPasswd(String passwd) {
this.passwd = passwd;
}
}
6、@Transient
可选:忽略该属性,当该字段不属于数据库的字段时候使用;
未完待续。。。