Hi.
I'm using OpenJPA 1.2.2 with OpenEJB 3.1.2, and facing an odd problem...
I have a BaseEntity class, which all other entities extend, with the following 
definition:

@MappedSuperclass
public abstract class BaseEntity {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Override
    public boolean equals(Object obj) {
        if (!getClass().isInstance(obj)) {
            return false;
        }
        BaseEntity other = (BaseEntity) obj;
        return id != null && id.equals(other.id);
    }

    public Long getId() {
        return id;
    }

    @Override
    public int hashCode() {
        return id == null ? System.identityHashCode(this) : id.hashCode();
    }

    @Override
    public final String toString() {
        return ClassHelper.getUnqualifiedName(getClass()) + "#" + id;
    }
}


When trying to persist a graph of objects, during flush, an StoreException is 
thrown, having as nested exceptions 3 times the following (probably 1 per 
instance persisted): 
<openjpa-1.2.2-r422266:898935 nonfatal user error> 
org.apache.openjpa.util.InvalidStateException: The generated value processing 
detected an existing value assigned to this field: package.BaseEntity.id.  This 
existing value was either provided via an initializer or by calling the setter 
method.  You either need to remove the @GeneratedValue annotation or modify the 
code to remove the initializer processing.

However, I'm not assigning a value by hand: I've debugged and what's there is 
actually the value generated by the DB identity...

The intriguing is that if I remove the id from equals(), toString() and 
hashCode(), no error is thrown. But if I do that, I can no longer trust 
HashMaps / HashSets.

Is there a solution for it?

Thanks in advance.

--
Luis Fernando Planella Gonzalez

Reply via email to