我有一个Spring项目,我正在使用hibernate。当我开始项目时,db没有变化。
我尝试了difrenf配置,但没有工作。
任何想法可能出错?
在servlet.xml中配置Hibernate:
<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" />
答案 0 :(得分:6)
使用
<prop key="hibernate.hbm2ddl.auto">create</prop>
根据文档,更新会更新现有架构。
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
答案 1 :(得分:1)
在开始项目之前创建项目并继续。大多数应用程序假设架构在启动时都是先验的。
答案 2 :(得分:0)
如果您已正确遵循所有程序但仍然收到错误,请检查&#34; hibernate.dialect&#34;如果您使用MySQL作为数据库,则设置为MySQL5Dialect。