我使用两种不同的方式查询db4o中的对象,我想讨论它.
1)在第一个例子中,我创建了一个ObjectContainer的实例,我打开连接,然后关闭它.
ObjectContainer db = Db4oEmbedded.openFile(Db4oEmbedded.newConfiguration(),"User"); ObjectSet result = db.queryByExample(user); db.close();
2)在这第二个例子中,我创建一个ObjectServer,让连接在应用程序的整个生命周期中打开.我也从ObjectServer中打开ObjectContainer,使我的查询然后关闭它:
ObjectServer userDb = Db4oClientServer.openServer(Db4oClientServer.newServerConfiguration(),"User",0); ObjectContainer client = client = userDb.openClient(); ObjectSet result = client.queryByExample(user); client.close();
–
两种方法的主要区别是什么?如果我从来没有关闭ObjectServer,是否有危险?
在我看来,第二种方法是更好的,因为如果两个不同的实例调用第一个例子中显示的方法,第二个调用者会得到异常,导致数据库被锁定,但在第二个例子中,我没有这样的问题.由于我对db4o的经验并不多,我更喜欢问我是否正确的方式.