这两天学习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开始生成主键了。