hibernate在配置文件中声明的表如果数据库中没有这张表会自动新建一个吗?

hibernate在配置文件中声明的表如果数据库中没有这张表会自动新建一个吗?,第1张

会,但是只建表不建库。

当引入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


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6629851.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-25
下一篇 2023-03-25

发表评论

登录后才能评论

评论列表(0条)

保存