... или даже это:

ли ограничение на количество соединений, разрешенных в запросе JPA / Hibernate?

С зимней спячкине присоединяется автоматическиЯ должен явно указать соединения в моем запросе JPA / Hibernate. Например, у человека есть адрес, у адреса есть состояние. Следующий запрос извлекает людей с полностью загруженным адресом и состоянием:

select p, a, s from person p left join p.address a left join a.state s where ...

Поскольку я продолжаю добавлять объединения, я в конечном итоге (после 12-13 оставленных объединений) достигаю предела, когда Hibernate генерирует недопустимый SQL:

Caused by: java.sql.SQLException: Column 'something69_2_' not found. 

У меня действительно установлен диалект Hibernate для моей реализации базы данных, MySQL:

<property name="hibernate.dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>

Существует ли ограничение на количество соединений, которые Hibernate может обрабатывать в одном запросе?

Изменить 1: Следующее находится в файле журнала:

could not read column value from result set: something69_2_; Column 'something69_2_' not found.

Тем не мение,something69_2_ не появляется в запросе SQL. Это как Hibernate сгенерировал SQL-запрос и ожидаетsomething69_2_ быть в результатах, чего нет.

Изменить 2: Подобная проблема задокументирована какнефиксированная ошибка Hibernate HHH-3035

Изменить 3: Это документированоГибернация ошибка HHH-3636, который был исправлен, но еще не является частью какого-либо релиза.

Изменить 4: Я собрал hibernate-core 3.3.2-SNAPSHOT, в котором есть исправление ошибки HHH-3636, и это не решает эту проблему.

Изменить 5: Поведение ошибки, кажется, вызвано несколькимиLEFT JOIN FETCH на отношениях ManyToMany или OneToMany. Один будет работать, два или три результата в баге.

Изменить 6: Вот трассировка стека:

javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not execute query
        at org.hibernate.ejb.AbstractEntityManagerImpl.throwPersistenceException(AbstractEntityManagerImpl.java:629)
        at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:73)
Caused by: org.hibernate.exception.SQLGrammarException: could not execute query
        at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:67)
        at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
        at org.hibernate.loader.Loader.doList(Loader.java:2214)
        at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2095)
        at org.hibernate.loader.Loader.list(Loader.java:2090)
        at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:388)
        at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:338)
        at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:172)
        at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1121)
        at org.hibernate.impl.QueryImpl.list(QueryImpl.java:79)
        at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:64)
        ... 69 more
Caused by: java.sql.SQLException: Column 'something69_2_' not found.
        at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1055)
        at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:956)
        at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:926)
        at com.mysql.jdbc.ResultSetImpl.findColumn(ResultSetImpl.java:1136)
        at com.mysql.jdbc.ResultSetImpl.getInt(ResultSetImpl.java:2777)
        at org.hibernate.type.IntegerType.get(IntegerType.java:28)
        at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:113)
        at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:102)
        at org.hibernate.loader.Loader.getKeyFromResultSet(Loader.java:1088)
        at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:553)
        at org.hibernate.loader.Loader.doQuery(Loader.java:689)
        at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224)
        at org.hibernate.loader.Loader.doList(Loader.java:2211)
        ... 77 more

Изменить 7: Причина всех этих объединений состоит в том, чтобы избегать выполнения Hibernate n + 1 запросов, см.Часто задаваемые вопросы о Hibernate Как можно избежать n + 1 запросов SQL SELECT при выполнении запроса Hibernate?

Ответы на вопрос(5)

Ваш ответ на вопрос