繁体   English   中英

Hibernate 是否自动在数据库中创建表

[英]Does Hibernate create tables in the database automatically

在阅读这个(存档的)教程时,他们没有提到在数据库中创建表的任何内容。 一旦我指定了它们,Hibernate 是否通过创建表和字段来自动处理它。

这是我的 bean 配置。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/WEB-INF/jsp/" p:suffix=".jsp" />
    
    <bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://127.0.0.1:3306/spring"/>
        <property name="username" value="monwwty"/>
        <property name="password" value="www"/>
    </bean>
    
    <bean id="mySessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="myDataSource" />
        <property name="annotatedClasses">
            <list>
                <value>uk.co.vinoth.spring.domain.User</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">create</prop>
            </props>
        </property>
    </bean>
    
    <bean id="myUserDAO" class="uk.co.vinoth.spring.dao.UserDAOImpl">
        <property name="sessionFactory" ref="mySessionFactory"/>
    </bean>
    
    <bean name="/user/*.htm" class="uk.co.vinoth.spring.web.UserController" >
        <property name="userDAO" ref="myUserDAO" />
    </bean>
    
</beans>

您的 hibernate.hbm2ddl.auto 设置应该定义创建数据库(选项是validatecreateupdatecreate-drop

是的,因为您的配置中有以下属性,所以在您的情况下确实如此。 这在测试期间没问题,但在生产中你需要禁用它。

<prop key="hibernate.hbm2ddl.auto">create</prop>

对我来说,即使hibernate.hbm2ddl.auto设置为update不起作用。 结果发现生成的创建 SQL 无效,因为我的一个列名( user )是一个 SQL 关键字。 这很轻微地失败了,在我检查日志之前并不明显发生了什么。

在 hibernate.cfg.xml 文件中添加以下属性

<property name="hibernate.hbm2ddl.auto">update</property>

顺便说一句,在你的实体类中,你必须像这样定义你的@Id:

@Id
@GeneratedValue(generator = "increment")
@GenericGenerator(name = "increment", strategy = "increment")
@Column(name = "id")
private long id;

如果您使用以下定义,它可能不起作用:

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private long id;

是的,Hibernate 可以通过hibernate.cfg.xml文件中的hibernate.hbm2ddl.auto属性进行配置,以在您的数据库中自动创建表,以便在表不存在的情况下将您的实体存储在其中。

这在开发过程中非常方便in-memory,可以在每次运行应用程序时或在测试期间使用新in-memory,数据库并创建一个新数据库。

如果属性hibernate.ddl-auto = update ,那么它不会自动创建表。 要自动创建表,您需要将属性设置为hibernate.ddl-auto = create

弹簧靴中使用的选项列表是

  • validate :验证架构,不对数据库进行任何更改。

  • 更新:更新架构。

  • create :创建模式,销毁以前的数据。

  • create-drop : 在会话结束时删除架构

  • none : 是所有其他情况

所以第一次你可以将它设置为create ,然后下次你应该将它设置为update

是的,你可以使用

<property name="hbm2ddl.auto" value="create"/>

Hibernate 可以代表您创建用于多对多映射的表、休眠序列和表,但您必须通过调用 Configuration 对象的 setProperty("hibernate.hbm2ddl.auto", "create") 来显式配置它。 默认情况下,它仅使用 DB 验证架构,如果不存在任何内容,则会通过给出错误“ORA-00942:表或视图不存在”而失败。

如果您进行上述配置,则执行操作的顺序将是:- a) 删除所有表和序列,如果它们尚不存在,则不要给出错误。 b) 创建所有表和序列 c) 更改带有约束的表 d) 将数据插入其中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM