Этот запрос:HQL выбрать из нескольких таблиц
Query query = HibernateUtil.getSessionFactory().getCurrentSession().createQuery("SELECT substring(a.account, 1, 6), a.ref, b.event_id, substring(a.admin, 1, :adminLength) FROM Parent a, Child b WHERE b.joinString = a.joinString AND b.event_id=:eventId AND substring(a.admin, 1, :adminLength) LIKE :admin AND a.date BETWEEN :from AND :to");
Производит заявление SQL, который работает в MySQL.
Однако, когда я Переберите ребенка List
я java.lang.ClassCastException
на линии for (int j = 0; j < allParent.get(i).getAllChild().size(); j++) {
этого цикла:
for (int i = 0; i < allParent.size(); i++) {
System.out.println(allParent.get(i));
for (int j = 0; j < allParent.get(i).getAllChild().size(); j++) {
System.out.println("Child: " + allParent.get(i).getAllChild().get(j).getID());
}
HibernateUtil.getSessionFactory().getCurrentSession().flush();
HibernateUtil.getSessionFactory().getCurrentSession().clear();
}
Parent.hbm.xml
<bag name="allChild" table="child" inverse="true" lazy="true" fetch="select">
<key property-ref="surname">
<column name="surname" not-null="true" />
</key>
<one-to-many class="com.test.Child" />
</bag>
Есть ли способ, которым я может запустить это заявление, используя Criteria
(или что-то еще) вместо этого и заселить и allParent
List
и allChild
List
связан с каждым Parent
в пределах allParent
?
Является ли child_id строковой переменной, и это было бы более полезно для нас, если вы покажете свои классы моделей. – harrybvp
Пожалуйста, разместите полную статистику стека. –