@ ElementCollectionを使用すると、load allはオブジェクトの複数インスタンスをロードしています。具体的には、collectionOfStringsの各要素に対して1つのインスタンスをロードしています。@ ElementCollection Java Persistence(Hibernate)により重複インスタンスがロードされる
たとえば、collectionOfStrings.size()== 4のMyClassの単一インスタンスを持つデータベースでは、すべてのMyClass値をロードする呼び出しは、ただ1つのオブジェクトではなくサイズ4(すべて同じオブジェクト)のリストを返します。
これを解決するクリーンで簡単な方法はありますか?
// Parent class is a @MappedSuperclass which may or may not be relevant to the issue
@Entity
public class MyClass extends ParentClass {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private long id;
@ElementCollection(fetch=FetchType.EAGER)
@IndexColumn(name="indexColumn")
private List<String> collectionOfStrings;
// other instance variables, constructors, getters, setters, toString, hashcode and equals
}
public class MyClassDAO_Hibernate extends GenericHibernateDAO<MyClass, Long> implements MyClassDAO {
@Override
public List<MyClass> loadAll() {
List<MyClass> entityList = null;
Session session = getSession();
Transaction trans = session.beginTransaction();
entityList = findByCriteria(session);
trans.commit();
return entityList;
}
}
protected List<T> findByCriteria(Session session, Criterion... criterion) {
Criteria crit = session.createCriteria(getPersistentClass());
for (Criterion c : criterion) {
crit.add(c);
}
return crit.list();
}
MyClassDAO myClassDAO = new MyClassDAO_Hibernate(); // in reality, implementation type is determined with a Factory
...
List<MyClass> myClassInstances = myClassDAO.loadAll();
おかげで、 HeavyE
編集:findByCriteria呼び出しを追加しました。
どのようにエンティティを読み込みますか? – axtavt
axtavt、私は私が本来含んでいないfindByCriteriaメソッドを追加しました。 – HeavyE