我正在使用Hibernate。如何配置 applicationContext.xml 以使其具有H2内存数据库 org.hibernate.dialect.H2Dialect 不起作用
Spring配置
featureType: layer,
答案 0 :(得分:2)
您没有连接到内存数据库。您的JDBC URL用于与本地主机的网络连接:
jdbc:h2:tcp://localhost/~/test
要使用内存中的H2,URL必须看起来像这样,其中包含mem
:
jdbc:h2:mem:testdb
在手册中,请参见In-Memory Database上的部分
答案 1 :(得分:0)
使用嵌入式db数据源(具有dbcp连接池)而不是drivermanager数据源。
<jdbc:embedded-database id="dataSource" type="H2">
<jdbc:script location="classpath:db/sql/create-db.sql" />
<jdbc:script location="classpath:db/sql/insert-data.sql" />
</jdbc:embedded-database>
<bean id="dbcpDataSource" class="org.apache.commons.dbcp2.BasicDataSource">
<property name="driverClassName" value="org.h2.Driver" />
<property name="url" value="jdbc:hsqldb:mem:dataSource" />
<property name="username" value="username" />
<property name="password" value="password" />
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" >
<property name="dataSource" ref="dbcpDataSource"></property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.H2Dialect</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
</props>
</property>
<property name="packagesToScan">
<list>
<value>com.emusicstore</value>
</list>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>