db4o: ActivationDepth, кажется, не имеет никакого эффекта (?) - PullRequest
1 голос
/ 23 сентября 2011

Может кто-нибудь объяснить мне, почему установка глубины активации, по-видимому, не действует в приведенном ниже примере кода?

В этом примере создаются объекты Block, у каждого из которых есть номер и дочерний блок..

Поскольку ActivationDepth установлен в '2', я ожидаю, что из базы данных будут извлечены только блоки 01 и 02, но возможно пройти через дочерние блоки вплоть до блока 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);
  }

}

1 Ответ

0 голосов
/ 26 сентября 2011

Лучше всего, если вам не хватает db4o-xxx-nqopt.jar, который содержит необходимые классы для оптимизации NQ.

Если запрос NQ не соответствует критериям для запуска оптимизированного db4o, он все равно запускает ваш запрос, но этовремя в качестве оценки, откуда необходимо активировать всех кандидатов.

Следует выводу DiagnoticToConsole () в следующих случаях:

Test02 $ 1 @ 235dd910 :: Невозможно предиката Native Queryзапустить оптимизирован.

Этот собственный запрос был выполнен путем создания экземпляров всех объектов класса-кандидата.

Рассмотрим упрощение выражения в методе Native Query.Если вы считаете, что обработчик Native Query должен лучше понимать ваш код, вам предлагается опубликовать код запроса на форумах db4o по адресу http://developer.db4o.com/forums

Чтобы это исправить, убедитесь, что по крайней мере db4o-xxx-core-java5.jar , db4o-xxx-nqopt-java5.jar , db4o-xxx-instrumentation-java5.jar и bloat-1.0.jar в вашем классе.В качестве альтернативы вы можете заменить все эти банки на db4o-xxx-all-java5.jar .

...