Спящий режим с использованием критериев setMaxResults, дающих SQLGrammarException - PullRequest
1 голос
/ 30 ноября 2010

Я сделал критерии, но когда я использую setMaxResults, это даст мне исключение SQLGrammarException. Но когда я комментирую setMaxResults, он будет работать, возвращая все записи после первого результата. Я использую базу данных MySQL.

Код:

return criteria
            .setFirstResult(start)
            .setMaxResults(end)
            .setFetchSize(end)
            .list();

Исключение:

org.hibernate.exception.SQLGrammarException: could not execute query
    at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:92)
    at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
    at org.hibernate.loader.Loader.doList(Loader.java:2536)
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2276)
    at org.hibernate.loader.Loader.list(Loader.java:2271)
    at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:119)
    at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1716)
    at org.hibernate.impl.CriteriaImpl.list(CriteriaImpl.java:347)

....

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ...

1 Ответ

4 голосов
/ 30 ноября 2010

Проблема теперь решена.У меня был неправильный диалект в спящих свойствах.Я скопировал свои свойства из другого проекта, который использовал SQL Server, но этот использует MySQL, поэтому неправильный диалект вызывал эту ошибку.

hibernate.dialect=org.hibernate.dialect.MySQLInnoDBDialect
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...