Hibernate中的hibernate.hbm2ddl.auto

      这两天学习EJB3的相关知识,在学习JPA相关知识的时候,发现一个奇怪的现象,我的数据库表莫名其妙的丢失或者数据表中的数据莫名其妙的丢失。在网上查了很多资料才发现原来是persistence.xml中的这句话的问题。

 

<properties>
	<property name="hibernate.hbm2ddl.auto" value="create-drop" />
</properties>

 

 

     也就是hibernate.hbm2ddl.auto这个属性在捣鬼,现在给出解释。

     hibernate.hbm2ddl.auto Automatically validate or export schema DDL to the database when the SessionFactory is created. With create-drop, the database schema will be dropped when the SessionFactory is closed explicitly. eg. validate | update | create | create-drop

其实这个参数的作用主要用于:自动创建|更新|验证数据库表结构。建议value="none"。

详细如下:

validate                加载hibernate时,验证创建数据库表结构。

create                   每次加载hibernate,重新创建数据库表结构,这就是导致数据库表数据丢失的原因。

create-drop          加载hibernate时创建,退出是删除表结构

update                 加载hibernate自动更新数据库结构

      我最开始的value=create-drop。也就是在停止该EJB工程的时候,执行了drop操作,所以数据表都没了,只剩下一个空空的数据库。之后EJB工程重新部署的时候,容器Jboss根据实体Bean重新创建了相应的数据表,因此我们看到的就是数据表还在,但是数据没了。那是因为数据表被重建了,所以当然数据没了,数据表删了又重建,所以还在。所以你还会发现,在数据表自增长的字段如自增型主键,又从初始值,如mysql从1开始生成主键了。

你可能感兴趣的:(数据结构,Hibernate,mysql,jpa,ejb)