DataNucleus + JDO:使用Composite Key检索对象(错误:NoSuchElementException)

时间:2016-05-24 13:20:51

标签: java hbase jdo datanucleus nosuchelementexception

我有一个ComposedIdKey类,用于为Customer类创建复合键。 我可以使用复合键在Hbase中成功插入此对象。 但是,当我尝试访问该对象时,请收到以下消息:

java.util.NoSuchElementException
        at java.util.StringTokenizer.nextToken(StringTokenizer.java:349)
        at DN_Schema.ComposedIdKey.<init>(ComposedIdKey.java:26)
        at DN_Schema.Customer_JDO3.dnNewObjectIdInstance(Customer_JDO3.java)
        at org.datanucleus.enhancer.EnhancementHelper.newObjectIdInstance(EnhancementHelper.java:221)
        at org.datanucleus.identity.IdentityManagerImpl.getApplicationId(IdentityManagerImpl.java:479)
        at org.datanucleus.ExecutionContextImpl.newObjectId(ExecutionContextImpl.java:3729)
        at org.datanucleus.api.jdo.JDOPersistenceManager.newObjectIdInstance(JDOPersistenceManager.java:1595)
        at org.datanucleus.api.jdo.JDOPersistenceManager.getObjectById(JDOPersistenceManager.java:1723)
        at Performance.DataNucleusPerfo.Read_Hbase(DataNucleusPerfo.java:109)

compososedIdKey

public class ComposedIdKey implements Serializable
{
    public String firstName;
    public String lastName;
    public String dateOfBirth;

    public ComposedIdKey ()
    {
    }

    /**
     * Constructor accepting same input as generated by toString().
     */
    public ComposedIdKey(String value)
    {
        StringTokenizer token = new StringTokenizer (value, "::");
        token.nextToken();               // className
        this.firstName = token.nextToken(); // field1
        this.lastName = token.nextToken(); // field2l
        this.dateOfBirth = token.nextToken(); // filed3
    }

    public boolean equals(Object obj)
    {
        if (obj == this)
        {
            return true;
        }
        if (!(obj instanceof ComposedIdKey))
        {
            return false;
        }
        ComposedIdKey c = (ComposedIdKey)obj;

        return firstName.equals(c.firstName) && lastName.equals(c.lastName) && dateOfBirth.equals(c.dateOfBirth);
    }

    public int hashCode ()
    {
        return this.firstName.hashCode() ^ this.lastName.hashCode() ^ this.dateOfBirth.hashCode() ;
    }

    public String toString ()
    {
        // Give output expected by String constructor
        return this.getClass().getName() + "::"  + this.firstName + "::" + this.lastName + "::" + this.dateOfBirth;
    }
}

我用来获取对象的代码:

Transaction tx = pm.currentTransaction();
        System.out.println("Retrieving Customer");
        Customer_JDO3 teste = null;
     try
            {
                tx.begin();
                teste = pm.getObjectById(Customer_JDO3.class,"10-10-10DataNucleus");

Hbase中的rowkey出现 10-10-10DataNucleus

我可以做错什么? 感谢

1 个答案:

答案 0 :(得分:2)

我认为你试图用&#34; ::&#34;分割ctor的条目。但是这个条目并没有包含这样的字符。