常规的思路是,设计好数据库,建好表,借助MyEclipse(也可以是其他IDE),自动生成映射,或者自己写映射。早就听说hibernate中可以自动生成表。但是一直没有试验。今天首先介绍其中的一个属性hbm2ddl.auto,这个就是这个方案的核心属性,有四个值:create,create-drop,update看看我们从网上查找到得资料:
<!-- 启动时删数据库中的表,然后创建,退出时不删除数据表
<property name="hbm2ddl.auto">create</property>-->
<!-- 启动时删数据库中的表,然后创建,退出时自动删除所有表
<property name="hbm2ddl.auto">create-drop</property>-->
<!-- 自动修改,如果表结构与实体类不一致,那么就修改表使它们一致,数据会保留
<property name="hbm2ddl.auto">update</property>-->
<!-- 自动校验,如果表结构与实体类不一致,那么不做任何操作,报错
<property name="hbm2ddl.auto">validate</property>-->
这样的话,设计实体类,直接写POJO,[color=green]然后写映射[/color],让hibernate帮我们生成数据库表。或者我们知道了manytoone onetomany [color=blue]我们完全可以只用注释的了。实体类。关于注释底下有说明。[/color]
主要是 在包ejb3-persistence 中,这种也是主要的是用到得是jpa的这种规则。我常用的几个属性在下面给了说明。
— @Entity:表示该类是一个可持久化的是实体类,标记了该注释的类可以由实体管理器EntityMangager来管理。
— @Table:表示该实体类映射为数据库中的指定的一个表。例如本例中Customer实体映射为数据库的表“customer”,使用的注释是@Table(name = "customer"),其中name的值为数据对应的表名“customer”。
— @Column:表示实体类的属性对应表中的指定字段。例如本例中属性“shortName”标注为@Column(name = "short_name") ,其中name的值为数据库中对应字段名“short_name”。
— @Id:表示该属性为该实体的主键。例如本例中属性“id”标注为@Id,表示属性id为表中对应的主键。
— 除了这些注释以外,使一个POJO类成为一个可持久化的Entity类还需要注意以下几点。
Ø 实体类必须有一个默认的无参数的构造方法,并且无参数的构造方法必须是public或protected的。
Ø 若要使实体类能够支持序列化,例如支持远程调用,可以实现Serializable接口。实现该接口是可选的,但建议实体类都实现这个接口。
将java实体类生成数据库表结构工具 java根据实体类生成表
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
Java使用JsonNode判断实体类非空
使用jsonNode去判断实体类的参数是否为空
jsonnode java hutool