《Java从入门到放弃》框架入门篇:使用注解的方式配置hibernate映射关系

之前我们都是使用配置文件的方式来生成的代码,虽然和JDBC比较简单了很多,但每次都在修改时需要既改实体类又改映射文件。还是有点麻烦。

所以,这一篇,我们来说说使用注解的方式来在接在实体类上配置映射关系。

第一步:新建一个项目,或者把之前项目中的实体类、映射文件,还有hibernate中的mapping标签都删除,然后在DBBrowser中再次生成实体类。如下图:

红框中的选项就表示直接在POJO上以注解的方式加上映射关系。注意括号内的hibernate版本,必须是3.2及以上的才行。

生成后的实体类(Author和Blog)代码我就不复制上来了,内容太多。使用到的注解如下所示:

@Entity @Table(name = "author", catalog = "blogdb")

@Id @GeneratedValue @Column(name = "id", unique = true, nullable = false)

@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "author")

@ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "author_id")

这些注解就不一一介绍了。主要说明一下映射关系的注解。

cascade属性的值对应有javax.persistence.CascadeType的几个选项。

PERSIST:添加时级联。

MERGE:更新时级联。

REMOVE:删除时级联。

ALL:    所有操作都级联(默认)。

如果你设置为ALL以外的值,你会发现,完全没有级联!!!

骗子啊骗子!!!!!

所以,如果你只需要在添加或更新时级联,一般这样设置。

@Cascade(value = {CascadeType.SAVE_UPDATE}),注意这儿的CascadeType是org.hibernate.annotations.CascadeType。

fetch属性:是否延时加载。值有:FetchType.LAZY和FetchType.EAGER。

mappedBy = "author":相当于之前的inverse="true"。

别的东西就没什么好说的了,随便猜都能猜出来效果,哈哈!!!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券