码迷,mamicode.com
首页 > Web开发 > 详细

Hibernate初入门4--hbm2ddl

时间:2015-07-09 06:13:11      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:

在hibernate的配置文件中,存在如下一段代码!!

1 <!-- Drop and re-create the database schema on startup -->
2  <property name="hbm2ddl.auto">create/create-drop/update/validate</property>

在学习当中,完全不知道其中属性标签的值所代表的含义!!标签值有如下四种:

(1)create

(2)create-drop

(3)update

(4)validate

---------------------------------------------------------------------------------------

(1)当其中属性值为create时

1  <!-- Drop and re-create the database schema on startup -->
2  <property name="hbm2ddl.auto">create</property>

运行前:

技术分享

运行结果如下:

技术分享

分析可知:当参数为create时,hibernate将会作出判断,判断是否存在需要操作的表。如果存在则将表删除再重新创建,否则则直接创建。(之所以存在Student、Teacher表是因为在实验前,已在配置文件中添加了Student、Teacher的映射,所以会对Student、Teacher表做操作)

运行后:

技术分享

(2)当属性值为Create-drop时,测试结果如下(先将Employee表删除)

运行前:

技术分享

运行结果:

技术分享

分析可知:create-drop与create具有相同特性,在运行时都会检测数据库中是否存在需要操作的表,如果存在则删除重建,不存在则直接新建;

但通过显示数据库中的表可知,在程序运行结束后,前面所重建或新建的表也会随着程序结束而被删除。

运行后:

技术分享

(3) 当属性值为update时

运行前:

技术分享

运行结果如下:

技术分享

运行后:
技术分享

分析可知:当数据库中不存在需要操作的表时,hibernate会自动创建此表。

当增加一个属性wage 时(即添加一个字段)

运行结果:

技术分享

运行后:

技术分享

分析可知:当数据库中存在需要操作的表时,hibernate不会将原表删除。由新增加字段可知,之前插入的信息未被删除,所以可知当数据库中存在需要操作的表时,hibernate不会将其删除,只是在原表的基础上修改。

当减少一个字段并修改另一字段类型时

运行结果:

技术分享

运行后:

技术分享

技术分享

分析可知:当删除字段时,新插入的数据不具备已删除字段,在表中以null形式表示只是为了不影响之前插入的数据,故在此字段上显示为null(通过select * from employee where branch=""; 结果可以得出),即删除字段时所插入的数据不具备所删除的字段。

技术分享

分析可知:当插入数据时,数据表仍具备删除的字段,因而再后续插入数据的过程中,需要加入删除的字段。

技术分享

分析可知:修改字段类型时所插入的数据与原数据存在字符相同时,通过查找方式无法找出。

但是,问题又来了,如下测试!!又与此结论不同了,求高手解释!!

技术分享

最终结论:只是根据映射文件去和数据库中的表对应起来,如果不一致,就更新表的结构,所以出现如此之多的前后矛盾。

当属性值为validate时

运行后:

技术分享

分析:坑爹,解释不了了!!!求看到的大婶解释解释!!目测跟update的很像。

别人的结论:校验映射文件和数据库中的表是不是能对应起来,不能对应报错,实际中常用(没看懂)

Hibernate初入门4--hbm2ddl

标签:

原文地址:http://www.cnblogs.com/tanzy114/p/4631809.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!