UserException:尝试打开另一个进程当前正在使用的odb数据库文件

时间:2015-06-16 15:49:25

标签: java objectdb

我有一个在Netbeans IDE中正确运行的应用程序,但在构建它之后,它不会在某个时间运行,应用程序在特定点停止响应事件。我能够在命令行中运行jar文件时重现这个问题,我得到了这个异常,我把它堆叠在这里

enter image description here

这是我在与对象db交互时使用的数据类是

public class DataClass {

private EntityManager em = null;
private EntityManagerFactory emf = null;
private long accNo;
public DataClass() {
    connectDatabase();
}

public DataClass(long accNo) {
    this.accNo=accNo;
    connectDatabase();
}

private void connectDatabase() {
    if (emf == null) {
        emf = Persistence.createEntityManagerFactory("Atm.odb");

    }
    if (em == null) {
        em = emf.createEntityManager();
    }

}

public Customer getAccount(long id) {
    connectDatabase();
    try {
        TypedQuery q = em.createQuery("SELECT cu FROM Customer cu where cu.id= :id", Customer.class);
        q.setParameter("id", id);
        Customer c=(Customer)q.getSingleResult();
        closeConnections();
        return c;
    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}


public void closeConnections(){
    emf.close();
    em.close();
}
}

在搜索谷歌之后,我仍然无法解决这个问题。但是,此异常仅在第二次运行应用程序后发生。如果我在重新启动系统后第一次运行应用程序。一切都很好,但关闭应用程序并重新运行后,会出现此问题。该应用程序是基于javafx建立的

2 个答案:

答案 0 :(得分:3)

在第一种情况下,你没有关闭你的应用程序。使用任务管理器并将其终止。 如果某些线程(通常是GUI)仍在运行,可能会发生这种情况。 实际上你应该预见到这样的行为,并确保在Java应用程序中它正确关闭 - 所有线程都已关闭。

答案 1 :(得分:0)

正如Alex上面所观察到的,你的第一次跑步可能还没有结束。

还要检查您是否关闭EntityManagerFactory以释放数据库文件。

如果您必须同时从多个进程访问数据库,则使用客户端 - 服务器模式而不是嵌入模式。