Mam jedną BaseEntity, która abstrakty id i wersja właściwość. ta klasa implementuje również kod skrótu i równe w oparciu o własność PK (id).Hibernate równa się i proxy
BaseEntity{
Long id;
Long version;
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((id == null) ? 0 : id.hashCode());
return result;
}
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
BaseEntity other = (BaseEntity) obj;
if (id == null) {
if (other.id != null)
return false;
} else if (!id.equals(other.id))
return false;
return true;
}
}
teraz dwa Jednostka A i B rozciąga BaseEntity jak poniżej
A extends BaseEntity{
`B b`
B getB(){return b;)
void setB(B b){this.b=b;}
}
B extends BaseEntity{
}
object b1;
object a1;
a1.set(b1);
session.save(a1) //cascade save;
ścisłej sesja załadować z leniwy b i próbują a1.getB(). Equals (b1) daje fałszywe ale jeśli porównać z a1.getB(). getId(). equals (b1.getId()) wtedy daje prawdziwe dziwne !! Myślę, że to ze względu na obiekt proxy proxy Java, tak czy inaczej, aby rozwiązać ten problem?
Dzięki, rozumiem. zgadzam się z tobą na problemy, które mogą wyniknąć ze względu na equals() i hashcode() oparte na Id. Myślę, że teraz pójdę z opcją instanceof, ponieważ wprowadzenie naturalnego identyfikatora na tym etapie w aplikacji byłoby trudne. –