`

hibernate.cfg.xml:hbm2ddl.auto配置

阅读更多

hibernate.cfg.xml 中hibernate.hbm2ddl.auto配置节点如下:

<properties> 
<property name="hibernate.show_sql" value="true" />      
<property name="hibernate.hbm2ddl.auto" value="create" /> 
</properties> 

 

hibernate.hbm2ddl.auto参数:validate | update | create | create-drop ,主要用于自动创建、更新、验证数据库表结构。如果不是此方面的需求建议set value="none"。

 

 

create:

每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。

 

create-drop :

每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。

 

update:

最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。

 

validate :

每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

 

 

注:

1.请慎重使用此参数,没必要就不要随便用。如果要用尽量使用update
2.如果发现数据库表丢失,请检查hibernate.hbm2ddl.auto的配置

分享到:
评论

相关推荐

    hibernate.cfg.xml文件

    5. **hibernate.hbm2ddl.auto**:此属性决定了Hibernate在启动时如何处理数据库模式。例如,`create`表示每次启动时都创建新表,`update`则更新已有表结构,`validate`验证表结构是否匹配,`none`则不做任何操作。 ...

    Hibernate.cfg.xml常用配置总结.docx

    &lt;property name="hibernate.hbm2ddl.auto"&gt;update &lt;property name="hibernate.default_schema"&gt;my_schema &lt;property name="hibernate.dialect"&gt;org.hibernate.dialect.MySQLDialect ... &lt;/hibernate-...

    Hibernate.cfg.xml常用配置总结.pdf

    需要注意的是,`Hbm2ddl.auto` 的配置尤其重要,因为错误的设置可能导致数据丢失或不必要的表结构修改。在生产环境中,通常不推荐使用 `create` 或 `create-drop`,以防止意外的数据破坏。相反,`update` 或 `...

    hibernate3 配置hbm2ddl和hbm2java所需jar

    要使用hbm2ddl,你需要在Hibernate配置文件(如hibernate.cfg.xml)中启用auto-import属性,并指定对应的schema更新策略。 2. hbm2java: hbm2java工具则将Hibernate的映射文件转换为Java实体类。这些实体类是与...

    hibernate完整配置文件

    7. `hbm2ddl.auto`: 自动处理数据库表的策略,可选`create`、`create-drop`、`update`或`validate`。 除了核心配置文件外,Hibernate还需要实体类的映射文件(通常以`.hbm.xml`为扩展名),这些文件定义了Java类与...

    Hibernate3所有包和配置文件

    - `hibernate.hbm2ddl.auto`: 自动创建、更新或验证数据库表结构,常用于开发环境。 5. **使用流程**: - 创建实体类并编写.hbm.xml映射文件。 - 配置hibernate.cfg.xml,设定数据库连接信息。 - 初始化...

    oracle的hibernate配置文件

    `hibernate.hbm2ddl.auto`控制数据库表的自动管理,`update`表示在启动时更新数据库结构。`hibernate.show_sql`开启后,Hibernate会打印执行的SQL语句。 3. SessionFactory配置: SessionFactory是Hibernate的...

    Hibernate配置文件

    - `hibernate.hbm2ddl.auto`: 控制数据库表的自动创建、更新或验证。常见的值有`create`(每次启动应用时新建表)、`update`(根据实体类更新表结构)和`validate`(检查表结构是否匹配)。 3. **缓存配置** - `...

    Hibernate 配置文件.ppt

    - `hbm2ddl.auto`:控制Hibernate在启动时自动创建、更新或删除数据库模式。可选值有`create`、`update`、`create-drop`和`validate`。 `jdbc.fetch_size`和`hibernate.jdbc.batch_size`是两个与数据库性能密切相关...

    Hibernate配置文.pdf

    - `&lt;property name="hbm2ddl.auto"&gt;`: 设置自动建表策略,如`update`表示更新已有表结构。 - `&lt;property name="connection.driver_class"&gt;`: 类似`hibernate.connection.driver_class`,定义JDBC驱动类。 总结,...

    Hibernate笔记 马士兵

    三、 Hibernate.cfg.xml:hbm2ddl.auto 16 四、 搭建日志环境并配置显示DDL语句 16 五、 搭建Junit环境 16 六、 ehibernate.cfg.xml : show_sql 17 七、 hibernate.cfg.xml :format_sql 17 八、 表名和类名不同,...

    springboot集成hibernate

    properties.setProperty("hibernate.hbm2ddl.auto", "update"); properties.setProperty("hibernate.show_sql", "true"); return properties; } } ``` 然后,我们可以创建一个DAO接口,例如`UserDAO`,并实现该...

    Hibernate配置[归类].pdf

    - `hbm2ddl.auto`属性控制Hbm2ddl工具的行为,如`update`表示在启动时更新数据库结构。 - `connection.driver_class`等其他属性与属性文件配置相似,用于指定JDBC驱动、连接URL等。 ### 5. `Session`的`load()`与`...

    hibernate_reference1.rar_配置文件

    - `&lt;property name="hibernate.hbm2ddl.auto"&gt;`: 自动创建、更新或验证数据库表结构,如`create-drop`、`update`等。 在实际开发中,开发者可以根据项目需求调整这些配置,以实现最佳性能和功能。例如,生产环境中...

    JBPM4的学习资料

    `hibernate.hbm2ddl.auto`属性控制数据库模式的自动更新。此外,`mapping resource`元素用于指定Hibernate映射文件的位置,这些文件定义了数据库中的表结构。 3. `log4j.hibernate.cfg.xml`:这个文件通常用于配置...

    Java应用中使用Hibernate.pdf

    3. 配置文件:Hibernate 的配置主要通过 XML 文件来完成,包括 hibernate.cfg.xml 和映射文件(如 Customers.hbm.xml)。在 hibernate.cfg.xml 中配置数据库连接参数,包括数据库 URL、用户名、密码、JDBC 驱动、...

    [应用开发及迁移][客户端编程开发框架]Hibernate指南.pdf

    &lt;property name="hbm2ddl.auto"&gt;create &lt;!-- 映射文件位置 --&gt; &lt;mapping resource="com/example/model/User.hbm.xml"/&gt; &lt;/hibernate-configuration&gt; ``` 在这个示例中,我们定义了一个 `session-factory`,并...

Global site tag (gtag.js) - Google Analytics