在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的很像。
别人的结论:校验映射文件和数据库中的表是不是能对应起来,不能对应报错,实际中常用(没看懂)