datanucleus+jdo:使用复合键检索对象(error:nosuchelementexception)

rm5edbpk  于 2021-06-09  发布在  Hbase
关注(0)|答案(1)|浏览(422)

我有一个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)

复合密钥

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
我会做错什么?谢谢

sauutmhj

sauutmhj1#

我认为您尝试将ctor的条目拆分为“:”,但该条目不包含此类字符。

相关问题