会,但是只建表不建库。
当引入hibernate时,可以创建数据库表的配置文件。可以根据表的配置文件自动在数据库建表。(数据库要预先建立好,因为hibernate只会建表,不会建库)
在配置文件 hibernate.cfg.cml 中加入参数 ,配置相关数据源参数和pojo文件。
update 表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。
#create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。
#create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。
具体代码如下:
<hibernate-configuration><session-factory>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
<property name="connection.username">root</property>
<property name="connection.password">mysecretpassword</property>
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hbm2dll.auto">update</property>
<property name="javax.persistence.validation.mode">none</property>
<property name="show_sql">true</property>
<mapping resource="com/bean/User.hbm.xml"/>
<mapping resource="com/bean/Journal.hbm.xml"/>
<mapping resource="com/bean/Article.hbm.xml"/>
<mapping resource="com/bean/Chapter.hbm.xml"/>
<mapping resource="com/bean/Paragraph.hbm.xml"/>
</session-factory></hibernate-configuration>
我们在搭建环境的时候,在配置文件中有一个属性标签为:<property name="hibernate.hbm2ddl.auto"></property>
这个属性标签中有四个参数可以写,这四个参数是对数据库中插入的进行不同的 *** 作,分别为:
(1)create-drop
(2)create
(3)update
(4)validate
下面分别来介绍他们的作用以及对数据库中的影响
(1)<property name="hibernate.hbm2ddl.auto">create-drop </property>
create-drop:表示在hebarinate初始化时创建表格,程序运行结束的时候会删除相应的表格,在实际项目中不用
(2)<property name="hibernate.hbm2ddl.auto">create</property>
在hibernate初始化时会创建表格,在运行结束之后不删除表格,而是在下一次运行的时候如果有旧的删掉,没有旧的,重新建表格
(3)<property name="hibernate.hbm2ddl.auto">update</property>
只是根据映射文件去和数据库中的表对应起来,如果不一致,就更新表的结构
(4)<property name="hibernate.hbm2ddl.auto">validate</property>
校验映射文件和数据库中的表是不是能对应起来,不能对应报错,实际中常用
引用于网址:http://www.linuxidc.com/Linux/2011-12/49206.htm
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)