Hibernate 常用实体类注解

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
可选:忽略该属性,当该字段不属于数据库的字段时候使用;

未完待续。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值