我有一个spring项目,我正在使用hibernate。当我启动项目时,db没有变化。
我尝试过difrenf配置,但都不起作用。
有什么想法可能是错的吗?
Hibernate在servlet.xml中配置:
<beans:beans xmlns="http://www.springframework.org/schema/beans"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns:context="http://www.springframework.org/schema/context"
         xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"
         xmlns:beans="http://www.springframework.org/schema/beans">
<context:component-scan base-package="com.springapp.mvc"/>
<!--Data source has the database information -->
<beans:bean id="dataSource"
            class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <beans:property name="driverClassName" value="org.postgresql.Driver"/>
    <beans:property name="url" value="jdbc:postgresql://localhost:5432/Praktyki"/>
    <beans:property name="username" value="dbusersolsoft"/>
    <beans:property name="password" value="dbpassSolsoft"/>
</beans:bean>
<!-- Session Factory -->
<beans:bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <beans:property name="dataSource" ref="dataSource"/>
    <beans:property name="packagesToScan">
            <value>com.springapp.mvc.model</value>
    </beans:property>
    <!--<beans:property name="showSql" value="true" />-->
    <!--<beans:property name="generateDdl" value="true" />-->
    <beans:property name="hibernateProperties">
        <beans:props>
            <prop key="hibernate.dialect">org.hibernate.dialect.HSQLDialect</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.show_sql">false</prop>
        </beans:props>
    </beans:property>
</beans:bean>
<bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor" />
发布于 2014-02-13 20:59:12
使用
<prop key="hibernate.hbm2ddl.auto">create</prop>根据文档,update将更新现有架构。
link以供参考。
简而言之,
validate: validate the schema, makes no changes to the database.
update: update the schema.
create: creates the schema, destroying previous data.
create-drop: drop the schema at the end of the session.
auto : Automatically validates or exports schema DDL to the database when the SessionFactory is created发布于 2014-02-13 20:33:41
在开始项目之前创建一次项目,然后继续。大多数应用程序在启动时都假定模式是先验存在的。
发布于 2018-03-11 00:09:39
如果您正确地遵循了所有步骤,但仍然收到错误,请检查"hibernate.dialect“是否设置为MySQL5Dialect,以防您使用MySQL作为数据库。
https://stackoverflow.com/questions/21754326
复制相似问题