在使用Hibernate时我们常在hibernate.cfg.xml文件中配置hibernate.hbm2ddl.auto,最常见的配置是create和update。当配置为create时每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
一般在开发中我会配置为update,第一次加载hibernate时根据model类会自动建立起表的结构,以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。但意外就在不经意间发生了,今天新建了几个model类重启服务器后在数据库里总是不生成对应表结构。最后一遍一遍查看配置文件,更换数据库用户之类的查找错误原因。最终发现如果所使用的数据库用户的角色是dba时hibernate.hbm2ddl.auto配置为update时,hibernate不会去自动生成表结构。
更深沉的原因没有去详查,希望对遇到同样问题的朋友有所帮助。