db4o - 计算数据库中的总记录数?

时间:2011-03-26 01:40:56

标签: java db4o

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

沃尔特

1 个答案:

答案 0 :(得分:4)

有两种方法:

第一个是查询type-object,然后获取计数:

  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内部类。所以我把它们过滤掉了。