用属性控制Hibernate生成DDL

栏目: Hibernate · 发布时间: 1年前

来源: fookwood.com

内容简介:Hiberate可以根据我们定义的@Entity实体类,来自动生成表结构,在一定程度上,你不需要与SQL打交道。在Spring Boot配合Hibernate使用的时候,可以定义属性来控制这种行为。如图所示:除了这个属性之外,Spring Boot还有另外一个属性:都是生成ddl相关的,他俩有啥区别呢?我翻阅了好多源码和

本文转载自:https://fookwood.com/hibernate-generate-ddl,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有。

Hiberate可以根据我们定义的@Entity实体类,来自动生成表结构,在一定程度上,你不需要与SQL打交道。在Spring Boot配合Hibernate使用的时候,可以定义属性来控制这种行为。如图所示:

用属性控制Hibernate生成DDL
可用的一些属性值
  • create表示每次应用启动的时候,都会将之前的表全部drop掉,重新根据实体类生成一遍。
  • create-drop在create的基础上,在应用关闭的时候还会drop一次。
  • update可能是比较常用的,每次启动的时候会看看实体类有什么变化,然后看需不需要更改表结构。
  • validate不会对表进行更改,但是会看看他和实体类是否对应
  • none什么都不做

除了这个属性之外,Spring Boot还有另外一个属性:

用属性控制Hibernate生成DDL

都是生成ddl相关的,他俩有啥区别呢?我翻阅了好多源码和 文档 ,得出了结论:spring.jpa.generate-ddl是更高层次上的抽象,他和具体的JPA实现无关,spring.jpa.hibernate.ddl-auto是和Hibernate相关的更具体的设置。前者会影响到后者,最好不要两者混用,容易混淆。在实践中,直接用后者就行。

如果你非得使用spring.jpa.generate-ddl,或者你看到别人用了他,那么你需要搞清楚:他的默认值是false,如果你显式设置为true,最后框架会选择update方式(从HibernateJpaVendorAdapter的源码可以看出)。

如果两个属性都没有配置,那么系统会判断你使用的是不是内置数据库(hsqldb, h2, derby),如果是的话会选用create-drop策略,其他情况是none策略。

好用么?

说实话,不堪重用。我将spring.jpa.hibernate.ddl-auto设置为update,同时把实体类的某个@Column属性删除了,按理说,我重新启动下应用,对应的字段应该被删除才对,但事实上,并没有。这就坑了,当需要精细地控制表结构的时候,你会感觉使不上力。

所以,在生产环境,还是不要用本文介绍的特性为好,选择更直接地方式去控制表结构。比如使用 Flyway 或者 Liquibase 来管理,因为你可以手写DDL相关的SQL语句,或者你们有DBA的话,交给他来处理。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

关注码农网公众号

关注我们,获取更多IT资讯^_^


为你推荐:

相关软件推荐:

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Google是如何控制世界的

Google是如何控制世界的

(美)丹尼尔·伊克比亚 / 李军 / 东方出版社 / 2008-08 / 36.00元

秘Google的发展之路! Google,这个有着数百亿的网页存储量、每天两亿搜索次数的搜索引擎,最初仅仅是一个方程式。这个由拉里·佩奇和塞吉·布林两位天才创造出的超级算法甚至比可口可乐的配方还要保密。 当广告公司为自己网页在搜索结果中的排序争得头破血流时,Google正悠然地坐收渔翁之利,这种天才的拍卖广告链接的商业模式给Google带来了令人瞠目结舌的企业利润!仅仅从1999~20......一起来看看 《Google是如何控制世界的》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具