在这个项目设置中,我尝试使用带有Hibernate的JPA作为提供程序,将数据存储在本地h2数据库中。它全部配置为我的spring项目的一部分,我使用tomcat作为我的服务器。在过去一周左右的时间里,我一直在思考一个基本问题,就是阻止我成功地完成我的应用程序工作。这就是应用程序与我的数据库通信的能力。最初,我将hibernate属性hbm2ddl设置为创建更新。使用此配置,虽然应用程序已成功启动,但没有数据被保存到本地H2数据库。但是这里要注意的一点是,数据是在JVM中持久化的。所以我可以取回储存的东西。请注意,尽管我没有在内存模式下运行h2数据库,但还是发生了这种情况。现在,在进行了一些研究之后,我意识到应该设置hbm2ddl属性来验证,因为我已经在使用H2控制台单独创建数据库模式。但是这里是我得到的hibernate例外,丢失的表。我通过调试第三方hibernate、c3p0和h2 jars进行了一些挖掘,但我确实碰到了问题。实际上,我可以在JdbcDatabaseMetaData驱动程序jar中看到创建准备语句的H2类,但是当执行该语句时,它返回空的结果集。好的,为了检查是否存在任何连接或查询相关的问题,我进行了准确的查询,并通过一个使用简单H2 Jdbc连接的独立程序来执行它。令人惊讶的是,我能够检索准确的数据,这些数据的缺失导致了“缺少表”hibernate异常。
有人知道这东西是为什么引起的吗?驱动程序工作正常,我想hibernate与此无关。这让我怀疑tomcat有什么东西阻止了与数据库的通信。任何评论,暗示,提示在这一点上将是非常感谢的。
下面是一些基本的配置。
持久化配置
<!-- datasource -->
<bean id="datasource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<!-- DB connection properties -->
<property name="driverClass" value="org.h2.Driver" />
<property name="jdbcUrl" value="${db.url}" />
<property name="user" value="${db.user:}" />
<property name="password" value="${db.password:}" />
<!-- Pool sizing properties -->
<property name="initialPoolSize" value="${db.pool.initialSize:5}" />
<property name="maxPoolSize" value="${db.pool.maxSize:25}" />
<property name="minPoolSize" value="${db.pool.minSize:0}" />
<property name="maxStatements" value="${db.pool.maxStatements:10}" />
<!-- Connection testing and acquisition properties -->
<property name="maxIdleTime" value="300" />
<property name="idleConnectionTestPeriod" value="${db.con.testPeriod:30}" />
<property name="preferredTestQuery" value="${db.con.testQuery:select 1 from dual}" />
<property name="acquireIncrement" value="${db.con.acquireIncrement:5}" />
<property name="acquireRetryAttempts" value="${db.con.retryAttempts:0}" />
<property name="acquireRetryDelay" value="${db.con.retryDelay:3000}" />
<!-- JMX name -->
<property name="dataSourceName" value="Datasource" />
<!-- Debugging options -->
<property name="unreturnedConnectionTimeout" value="${db.con.unreturnedTimeout:0}" />
<property name="debugUnreturnedConnectionStackTraces" value="${db.con.debugUnreturned:false}" />
</bean>
<bean id="emf" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="datasource"/>
<property name="packagesToScan" value="com.omni" />
<property name="persistenceProviderClass" value="org.hibernate.ejb.HibernatePersistence"/>
<property name="jpaDialect">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />
</property>
<property name="jpaProperties">
<props>
<prop key="hibernate.dialect">${db.hib.dialect}</prop>
<!-- <prop key="hibernate.default_schema">${db.hib.schema:SVC_APP}</prop> -->
<prop key="hibernate.id.new_generator_mappings">true</prop>
<prop key="hibernate.jdbc.batch_versioned_data">true</prop>
<prop key="hibernate.connection.isolation">${db.hib.isolationLevel:4}</prop>
<prop key="hibernate.jdbc.fetch_size">${db.hib.fetchSize:50}</prop>
<prop key="hibernate.max_fetch_depth">${db.hib.maxFetchDepth:3}</prop>
<prop key="hibernate.default_batch_fetch_size">${db.hib.defBatchSize:8}</prop>
<prop key="hibernate.hbm2ddl.auto">${db.hib.ddl:none}</prop>
<prop key="hibernate.generate_statistics">${db.hib.genStats:true}</prop>
<prop key="hibernate.format_sql">${db.hib.formatSql:false}</prop>
<prop key="hibernate.ejb.interceptor">com.omni.core.support.hibernate.AuditInterceptor</prop>
<prop key="hibernate.show_sql">true</prop>
<!--<prop key="hibernate.default_catalog">DEALS</prop> -->
</props>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="emf" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager"/>
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor" />这是我得到丢失表错误消息的实体文件。
@Entity
@Table(name="CUSTOMER")
public class CustomerEt {
private String id;
private String lastName;
private String firstName;
private String middleName;
@Id
@Column(name="CUSTOMER_ID")
public String getId() {
return id;
}
@Column(name="LAST_NAME")
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
@Column(name="FIRST_NAME")
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
@Column(name="MIDDLE_NAME")
public String getMiddleName() {
return middleName;
}
public void setMiddleName(String middleName) {
this.middleName = middleName;
}
}发布于 2015-01-21 16:19:55
谢谢你回答我的问题。我终于用我的装置解决了问题。H2正在运行嵌入式模式。我假设即使在嵌入式模式下,即使JVM被关闭,数据也应该保持不变。然而,这对我来说显然不是事实。因此,当我将其改为TCP/服务器模式时,所有这些操作都很顺利,没有任何问题。
如果其他人面临同样的问题,请在此发表评论,我很乐意提供帮助。
https://stackoverflow.com/questions/27870581
复制相似问题