***********************************************************

这两天在整理Spring + JPA(Hibernate实现),从网上copy了一段Hibernate连接参数的配置。

<properties>
<property name="hibernate.show_sql" value="true" />      
<property name="hibernate.hbm2ddl.auto" value="create" />
</properties>
结果在测试时,老是发现数据库表数据丢失。这个参数以前没怎么用,查了一圈其它的东东,最后才定位到这个上面。赶紧查了一下Hibernate的参数配置,解释如下:

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

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

其它几个参数的意思,我解释一下:

validate                加载hibernate时,验证创建数据库表结构
create                  每次加载hibernate,重新创建数据库表结构,这就是导致数据库表数据丢失的原因。
create-drop          加载hibernate时创建,退出是删除表结构
update                 加载hibernate自动更新数据库结构

以上4个属性对同一配置文件下所用有的映射表都起作用

总结:

1.请慎重使用此参数,没必要就不要随便用。

2.如果发现数据库表丢失,请检查hibernate.hbm2ddl.auto的配置

***********************************************************

hibernate.hbm2ddl.auto

Hibernate Reference Documentation 3.3.1解释如下:

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

其实这个hibernate.hbm2ddl.auto参数的作用主要用于:

自动创建|更新|验证数据库表结构。

如果不是此方面的需求建议set value="none"。
create:
每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
create-drop :
每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。

update:
最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。
validate :
每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

再说点“废话”:
当我们把hibernate.hbm2ddl.auto=create时hibernate先用hbm2ddl来生成数据库schema。
当我们把hibernate.cfg.xml文件中hbm2ddl属性注释掉,这样我们就取消了在启动时用hbm2ddl来生成数据库schema。通常 只有在不断重复进行单元测试的时候才需要打开它,但再次运行hbm2ddl会把你保存的一切都删除掉(drop)---- create配置的含义是:“在创建SessionFactory的时候,从scema中drop掉所以的表,再重新创建它们”。
注意,很多Hibernate新手在这一步会失败,我们不时看到关于Table not found错误信息的提问。但是,只要你根据上面描述的步骤来执行,就不会有这个问题,因为hbm2ddl会在第一次运行的时候创建数据库schema, 后续的应用程序重启后还能继续使用这个schema。假若你修改了映射,或者修改了数据库schema,你必须把hbm2ddl重新打开一次。

hibernate.hbm2ddl.auto配置及意义相关推荐

  1. hibernate.hbm2ddl.auto配置详解

    hibernate.hbm2ddl.auto配置详解 http://www.cnblogs.com/feilong3540717/archive/2011/12/19/2293038.html hib ...

  2. Hibernate hbm2ddl.auto配置的可能值是什么,它们做了什么

    本文翻译自:What are the possible values of the Hibernate hbm2ddl.auto configuration and what do they do I ...

  3. hibernate中hibernate.hbm2ddl.auto配置讲解

    2019独角兽企业重金招聘Python工程师标准>>> 介绍其中的一个属性hbm2ddl.auto,这个就是这个方案的核心属性,有四个值:create,create-drop,upd ...

  4. Nhibernate.hbm2ddl.auto配置详解

    hibernate.cfg.xml 中hibernate.hbm2ddl.auto配置节点如下: <properties> <property name="hibernat ...

  5. hibernate.hbm2ddl.auto的value

    Hibernate 配置参数hibernate.hbm2ddl.auto Hibernate中的配置文件: <properties> <property name="hib ...

  6. hibernate hbm2ddl.auto 问题

    为什么80%的码农都做不了架构师?>>>    <property name="hibernate.show_sql" value="true&q ...

  7. Hibernate:hbm2ddl.auto =在生产中更新?

    本文翻译自:Hibernate: hbm2ddl.auto=update in production? 是否可以运行使用hbm2ddl.auto=update配置的Hibernate应用程序来更新生产 ...

  8. Hibernate中SessionFactory配置

    SessionFactory配置 因为Hibernate被设计为可以在许多不同环境下工作,所以它有很多配置参数.幸运的是,大部分都已经有默认值了,Hibernate发行包中还附带有示例的hiberna ...

  9. firebird——Spring hibernate 集成连接配置

    -Djava.library.path=.\lib\ firebird版本是2.5, 嵌入式类库是2.2 这些都可以从官网中下载. 我用的是netbeans,在java 项目中新建一个lib文件夹,把 ...

最新文章

  1. 作为一枚第二天上班的小小.net程序员(技术宅的那种)很迷茫哦,第一个随笔
  2. 部署篇01:Linux 安装配置JDK
  3. Linux getopt()函数 getopt_long()函数---转
  4. 人工智能 | 人脸识别研究报告(概念篇)
  5. 《图解CSS3:核心技术与案例实战》
  6. 知识图谱论文阅读(二十三)【SIGIR2020】Multi-behavior Recommendation with Graph Convolutional Networks
  7. 【Linux入门学习之】vi/vim编辑器必知必会
  8. php微信个性化菜单,微信公众平台新增个性化菜单接口,实现公众号
  9. Android 系统(252)---Android:BLE智能硬件开发详解
  10. 查找路径php.ini文件到底在哪里?
  11. 普通的人改变结果,优秀的人改变原因,顶级优秀的人改变模型
  12. 【Kafka】测试Kafka整合Flume
  13. 毕业10年,阻碍你职业发展的最大“拦路虎”到底是什么?
  14. ASP.NET Web应用程序和ASP.NET网站的区别
  15. 【三维点云滤波】对三维点云空间数据进行滤波的matlab仿真
  16. 试论软件开发项目的成功因素
  17. 应广单片机芯片PMS132B -SOP8/SOP14/SOP16
  18. 数据结构(C语言)二叉树的链式存储与操作 11月18日
  19. My First Plug-in - Inventor API .NET 开发从0开始-课程3
  20. JS打开选择本地文件的对话框

热门文章

  1. Kotlin学习笔记(六) 伴生对象 对象表达式
  2. BZOJ3527:[ZJOI2014]力(FFT)
  3. 全球最大IXP为何选择与华为开展数据中心互联合作?
  4. RHEL5下的DHCP服务和DHCP中继
  5. [CSS]详解display:inline | block |inline-block的区别
  6. python3 32位_Python 3.6.8软件安装教程
  7. flex 下对齐_CSS3中Flex弹性布局该如何灵活运用?
  8. WAP2.0开发规范及原则
  9. mysql 唯一索引 二叉法_mysql 唯一索引
  10. ifix如何设画面大小_天涯明月刀手游研发揭秘:如何做出有“豪华感”的国风MMO大世界?...