项目重建后Hibernate H2数据库锁定

时间:2017-07-25 17:55:50

标签: java spring hibernate tomcat7 h2

我正在设置一个Spring hibernate H2应用程序。当服务器启动时一切正常但在更新后(在eclipse中重建项目而不重新启动Tomcat)我收到以下错误消息,指出无法访问数据库文件。

错误讯息:

java.lang.IllegalStateException: The file is locked: nio:/home/bob/dataStore.mv.db [1.4.187/7]

java.nio.channels.OverlappingFileLockException

org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Database may be already in use:

在Google上搜索此错误后,我尝试将File_LOCK=NODB_CLOSE_ON_EXIT=TRUE添加到网址但没有运气。

Context.xml档案

<context:annotation-config />
    <context:component-scan base-package="com" />

    <mvc:annotation-driven />

    <mvc:resources mapping="/resources/**" location="/resources/" />


    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="org.h2.Driver" />
<!--       <property name="url" value="jdbc:h2:tcp://localhost/~/dataStore;FILE_LOCK=NO;DB_CLOSE_ON_EXIT=TRUE" /> -->
        <property name="url" value="jdbc:h2:file:~/dataStore;FILE_LOCK=NO;DB_CLOSE_ON_EXIT=TRUE;MVCC=TRUE" />

        <property name="username" value="" />
        <property name="password" value="" />
    </bean>

    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="com.entities" />
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.H2Dialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.enable_lazy_load_no_trans">true</prop>
                <prop key="format_sql">true</prop>
                <prop key="use_sql_comments">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
            </props>
        </property>
    </bean>

    <tx:annotation-driven transaction-manager="transactionManager" />

    <bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

我可以做什么,以便每次重建项目时都不会锁定数据库。

此外,eclipse每次更新数据库后都会重建应用程序。我怎么能阻止这个?

2 个答案:

答案 0 :(得分:1)

从Spring docs

中尝试DB_CLOSE_ON_EXIT=FALSE
  

如果由于某种原因,您确实为嵌入式数据库配置了连接URL,则应注意确保禁用数据库的自动关闭。如果您正在使用H2,则应使用DB_CLOSE_ON_EXIT = FALSE来执行此操作。

答案 1 :(得分:-1)

如果需要创建multipul connecation,那么您需要使用以下代码:

<property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost/C:\Database\Data\production;"/>