hibernate.hbm2ddl.auto配置详解
发布日期:2021-05-15 22:07:48 浏览次数:12 分类:精选文章

本文共 665 字,大约阅读时间需要 2 分钟。

转载于:

在用SSH搭建一个OA项目的时候,发现搭建都OK,数据增删改查也都没有问题,但是在重启服务器时,之前操作的数据都没有了,查看数据库只有表结构没有数据,经过百般查找发现出在了hibernate.cfg.xml中的一个属性的配置上:

create
  • 1

下面我就来解释一下这个属性的值的区别:

在hibernate3.3.1版本的文档中这们解释

这里写图片描述

其实这个hibernate.hbm2ddl.auto参数的作用主要用于:自动创建|更新|验证数据库表结构。如果不是此方面的需求建议set value=”none”。

create:
每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
create-drop :
每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。
update:
最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。
validate :
每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

上一篇:Hibernate各种主键生成策略与配置详解
下一篇:List.remove()的两个重载方法

发表评论

最新留言

做的很好,不错不错
[***.243.131.199]2025年04月29日 03时59分30秒