加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – db4o从db中查询对象的最佳做法

发布时间:2020-12-15 06:53:47 所属栏目:百科 来源:网络整理
导读:我使用两种不同的方式查询db4o中的对象,我想讨论它. 1)在第一个例子中,我创建了一个ObjectContainer的实例,我打开连接,然后关闭它. ObjectContainer db = Db4oEmbedded.openFile(Db4oEmbedded.newConfiguration(),"User");ObjectSet result = db.queryByExam
我使用两种不同的方式查询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的经验并不多,我更喜欢问我是否正确的方式.

解决方法

当您在整个应用程序生命周期中保持连接打开时,db4o效果最佳.

如果您检索对象,请关闭数据库,重新打开并再次存储该对象db4o将不会意识到对象已被存储(因为您已关闭连接以及db4o的引用系统),并将存储第二个实例.

另一个问题(如果您在嵌入式模式下运行db4o)是打开数据库是一个耗时的操作,所以如果你继续打开/关闭数据库肯定会有性能问题(另一方面,打开客户端连接不是这样昂贵,所以应该没有问题).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读