hibernate.hbm2ddl.auto属性使用create而不是update创建表

hibernate.hbm2ddl.auto属性使用create而不是update创建表,hibernate,hbm2ddl,Hibernate,Hbm2ddl,数据库表不是由更新设置自动创建的 它适用于create 配置: <?xml version="1.0" encoding="UTF-8"?> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></pr

数据库表不是由更新设置自动创建的

它适用于create

配置:

<?xml version="1.0" encoding="UTF-8"?>

<bean id="dataSource"
    class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName"
        value="com.mysql.cj.jdbc.Driver"></property>
    <property name="url"
        value="jdbc:mysql://localhost:3306/StrutsPractice"></property>
    <property name="username" value="root"></property>
    <property name="password" value="root"></property>
</bean>

<bean id="mysessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource"></property>

    <property name="mappingResources">
        <list>
            <value>com/hbm/person.hbm.xml</value>
        </list>
    </property>


    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.show_sql">true</prop>
        </props>
    </property>
</bean>

<bean id="d" class="com.DAO.PersonDAO">
    <property name="sf" ref="mysessionFactory"></property>
</bean>

如果数据库中不存在表,则应自动创建该表。

hbm2ddl.auto的可能值及其说明如下:

创建-创建一个模式

更新-更新现有架构

验证-验证现有架构


create drop-在会话开始和结束时自动创建和删除架构

Hibernate版本?Hibernate版本为4.0.0。最后将您的方言更改为org.Hibernate.dial.mysqldial,然后重试