【问题标题】:db4o - count number of total records in database?db4o - 计算数据库中的总记录数?
【发布时间】:2011-03-26 01:40:56
【问题描述】:

我正在使用 db4o 并且想知道如何获取数据库中的对象总数?没有使用 API 的明确方式;但是,我可以编写一个查询来简单地计算所有对象,但我希望有一种更直接的方法来做到这一点。

沃尔特

【问题讨论】:

  • 记录?我以为 db4o 是一个对象数据库?你如何定义一个记录?这不是关系。

标签: java db4o


【解决方案1】:

有两种方式:

第一个是查询type-object然后得到count:

  int numberOfObjects = container.query(Object.class).size();

但是这可能很慢,因为查询会构造一个包含所有对象的结果列表。而在大型数据库中可能需要时间。

第二个是读取所有存储类的元数据并求和计数。这当然要快得多:

    int numberOfObjects = 0;
    for(StoredClass storedClass : container.ext().storedClasses()){
        // Filter out db4o internal objects
        // and filter out object which have a parent-class, because these are in the count of the parent
        if(!storedClass.getName().startsWith("com.db4o") &&
                null==storedClass.getParentStoredClass()) {
            numberOfObjects += storedClass.instanceCount();
        }
    }
    System.out.println("Number of objects stored "+numberOfObjects);

注意这里它还报告 db4o 内部类。所以我把它们过滤掉。

【讨论】:

  • 使用此代码,如果您有两个类的继承层次结构,您将多次获取层次结构中每个类的instanceCount。如果你添加一个额外的检查并且只添加没有父类的类的 instanceCount,那么你应该没问题。
  • 酷,这正是我的想法。这可能与不从 db4o 发布此功能一样优雅。
猜你喜欢
  • 2021-09-18
  • 1970-01-01
  • 1970-01-01
  • 2016-03-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-11-07
  • 1970-01-01
相关资源
最近更新 更多