关于Spring整合Hibernate中自动建表问题(hbm2ddl.auto)

时间:2021-02-23 08:19:56

1、在单独的使用Hibernate时,在Hibernate映射文件(*.hbm.xml)中配置好各个类的关系,然后再Hibernate配置文件(hibernate.cfg.xml)中添加属性可以自动在数据库中创建表结构(注:只能创建表,而非创建库)。

主要代码如下:

 <!--自动在数据库中建立表 -->
       <property name="hbm2ddl.auto">create</property>

 

2、在我使用spring mvc 整合hibernate时,代码如下:

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

运行程序,提示 * 表不存在,可见自动建表并未成功。

 

3、解决方法。

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

 

分析:可能是在spring配置文件中,并不识别“hbm2ddl.auto”项,所以该项配置根本没起到作用,而使用“hibernate.hbm2ddl.auto”,spring的配置文件是可以识别的,问题得到解决。期待有更权威的解释。