Problemi con l'API Berkeley DB JE Base database secondari e sequenze
-
21-09-2019 - |
Domanda
Ho un documento di classe che consiste di Id (int)
e Url (String)
. Mi piacerebbe avere un indice primario sul Id
e indice secondario su Url
. Vorrei anche avere una sequenza di auto-Id Incremento. Così creo un SecondaryDatabase e poi creare una sequenza. Durante l'inizializzazione della Sequenza ottengo un'eccezione:
Exception in thread "main" java.lang.IllegalArgumentException
at com.sleepycat.util.UtfOps.getCharLength(UtfOps.java:137)
at com.sleepycat.util.UtfOps.bytesToString(UtfOps.java:259)
at com.sleepycat.bind.tuple.TupleInput.readString(TupleInput.java:152)
at pl.edu.mimuw.zbd.berkeley.zadanie.rozwiazanie.MyDocumentBiding.entryToObject(MyDocumentBiding.java:12)
at pl.edu.mimuw.zbd.berkeley.zadanie.rozwiazanie.MyDocumentBiding.entryToObject(MyDocumentBiding.java:1)
at com.sleepycat.bind.tuple.TupleBinding.entryToObject(TupleBinding.java:76)
at pl.edu.mimuw.zbd.berkeley.zadanie.rozwiazanie.UrlKeyCreator.createSecondaryKey(UrlKeyCreator.java:20)
at com.sleepycat.je.SecondaryDatabase.updateSecondary(SecondaryDatabase.java:835)
at com.sleepycat.je.SecondaryTrigger.databaseUpdated(SecondaryTrigger.java:42)
at com.sleepycat.je.Database.notifyTriggers(Database.java:2004)
at com.sleepycat.je.Cursor.putNotify(Cursor.java:1692)
at com.sleepycat.je.Cursor.putInternal(Cursor.java:1616)
at com.sleepycat.je.Cursor.putNoOverwrite(Cursor.java:663)
at com.sleepycat.je.Sequence.<init>(Sequence.java:188)
at com.sleepycat.je.Database.openSequence(Database.java:546)
at pl.edu.mimuw.zbd.berkeley.zadanie.rozwiazanie.MyFullTextSearchEngine.init(MyFullTextSearchEngine.java:131)
at pl.edu.mimuw.zbd.berkeley.zadanie.testy.MyFullTextSearchEngineTest.main(MyFullTextSearchEngineTest.java:18)
Sembra che durante l'inizializzazione della sequenza del database secondario è costretto ad aggiornare. Quando metto a punto il metodo di entryToObject MyDocumentBiding i byte che si cerca di convertire in oggetto sembrare casuale.
Che cosa sto facendo di sbagliato?
Soluzione
ho scoperto che la soluzione è quella di creare un db separato per la sequenza o per rendere il SecondaryKeyCreator rilevare quando si aggiunge un dato sequenza e restituire false in tale situazione.