有人可以向我解释为什么设置
激活深度似乎无效
在下面的代码示例中?

此示例创建都具有的“块”对象
一个数字和一个子块。

由于ActivationDepth设置为“ 2”,我希望
只能从
数据库,但可以遍历子块
一路下降到块05(?)。

我想这意味着对象的整个图
加载而不是仅加载级别01和02,即
正是我试图通过设置激活深度来避免的事情。

这是完整的代码示例:

import com.db4o.Db4oEmbedded;
import com.db4o.ObjectContainer;
import com.db4o.ObjectSet;
import com.db4o.config.CommonConfiguration;
import com.db4o.config.EmbeddedConfiguration;
import com.db4o.query.Predicate;

public class Test02
{
  private final String DATABASE_NAME = "MyDatabase";

  public static void main(String[] args)
  {
    new Test02().test();
  }

  public void test()
  {
    storeContent();
    exploreContent();
  }

  private void storeContent()
  {
    Block block01 = new Block(1);
    Block block02 = new Block(2);
    Block block03 = new Block(3);
    Block block04 = new Block(4);
    Block block05 = new Block(5);
    Block block06 = new Block(6);

    block01.setChild(block02);
    block02.setChild(block03);
    block03.setChild(block04);
    block04.setChild(block05);
    block05.setChild(block06);

    ObjectContainer container = Db4oEmbedded.openFile(Db4oEmbedded.newConfiguration(), DATABASE_NAME);
    try
    {
      container.store(block01);
      container.store(block02);
      container.store(block03);
      container.store(block04);
      container.store(block05);
      container.store(block06);
    }
    finally
    {
      container.close();
    }
  }

  private void exploreContent()
  {
    EmbeddedConfiguration configEmbedded = Db4oEmbedded.newConfiguration();
    CommonConfiguration configCommon = configEmbedded.common();
    configCommon.activationDepth(2); // Global activation depth.

    ObjectContainer container = Db4oEmbedded.openFile(configEmbedded, DATABASE_NAME);

    try
    {
      int targetNumber = 1;
      ObjectSet blocks = getBlocksFromDatabase(container, targetNumber);

      System.out.println(String.format("activationDepth : %s ", configEmbedded.common().activationDepth()));
      System.out.println(String.format("Blocks found    : %s ", blocks.size()));

      Block block = blocks.get(0);
      System.out.println(block);                                   // Block 01
      System.out.println(block.child);                             // Block 02
      System.out.println(block.child.child);                       // Block 03 // Why are these
      System.out.println(block.child.child.child);                 // Block 04 // blocks available
      System.out.println(block.child.child.child.child);           // Block 05 // as well ??
      // System.out.println(block.child.child.child.child.child);  // Block 06
    }
    finally
    {
      container.close();
    }
  }

  private ObjectSet getBlocksFromDatabase(ObjectContainer db, final int number)
  {
    ObjectSet results = db.query
    (
      new Predicate()
      {
        @Override
        public boolean match(Block block)
        {
          return block.number == number;
        }
      }
    );

    return results;
  }
}

class Block
{
  public Block child;
  public int number;

  public Block(int i)
  {
    number = i;
  }

  public void setChild(Block ch)
  {
    child = ch;
  }

  @Override
  public String toString()
  {
    return String.format("Block number %s / child = %s ", number, child.number);
  }

}

最佳答案

最好的选择是您缺少db4o-xxx-nqopt.jar,其中包含NQ优化所需的类。

当NQ查询失败时,运行优化的db4o的条件仍将运行您的查询,但这一次作为评估,它需要激活所有候选者。

在这种情况下,遵循DiagnoticToConsole()的输出:


  Test02 $ 1 @ 235dd910 ::无法优化本机查询谓词。
  
  通过实例化候选类的所有对象来运行此本机查询。
  
  考虑简化本机查询方法中的表达式。如果您认为本机查询处理器应该更好地理解您的代码,请您在http://developer.db4o.com/forums上的db4o论坛上发布查询代码。


要解决此问题,请确保至少db4o-xxx-core-java5.jar,db4o-xxx-nqopt-java5.jar,
db4o-xxx-instrumentation-java5.jar和bloat-1.0.jar在您的类路径中。或者,您可以将所有这些jar替换为db4o-xxx-all-java5.jar。

关于java - db4o:ActivationDepth似乎没有效果(?),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7533350/

10-11 10:49