Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Hibernate+HQL+delete, не выполняется запрос 
:(
    Опции темы
vzf
Дата 14.2.2007, 15:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Помогите пожалуйста решить проблему. 
Есть класс JobLog соответствующий таблице JOBLOG. В таблице есть поле JOB_ID. В классе JobLog ему соответствует свойство jobId.

Мне необходимо при помощи запроса на HQL удалить записи из базы у которых значение JOB_ID равно указанному значению.

Я пишу следующий метод:
Код


    public int deleteAllLogsForJobId(Long jobId)  {
        int deletedEntitties = 0;

        try {
            Query q = 
                getSession().createQuery("delete JobLog j where j.jobId = :jobId" );
          
            q.setLong("jobId", jobId);
            deletedEntitties = q.executeUpdate();
            log.debug(deletedEntitties + " entities of JobLog was deleted");
        
        } catch (RuntimeException e) {
            log.debug(e.toString());
        }
        
        return deletedEntitties;
    }


При выполнении выбрасывается исключение:

Код

org.hibernate.QueryException: query must begin with SELECT or FROM: delete [delete JobLog j where j.jobId = :jobId]


В чем причина немогу понять. Я вроде стараюсь сделать все как в примерах из документации

Этот пример взят из документации:

Код

Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
String hqlDelete = "delete Customer c where c.name = :oldName";
// or String hqlDelete = "delete Customer where name = :oldName";
int deletedEntities = s.createQuery( hqlDelete )
.setString( "oldName", oldName )


Вот еще один (правда про update):

Код

Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
String hqlVersionedUpdate = "update versioned Customer set name = :newName where name = :oldName";
int updatedEntities = s.createQuery( hqlUpdate )
.setString( "newName", newName )
.setString( "oldName", oldName )
.executeUpdate();
tx.commit();
session.close();

--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
tux
Дата 14.2.2007, 16:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



В SQL синтаксис такой:
Код

delete from Customer c where c.name = :oldName

Попробуй.
PM MAIL Skype GTalk Jabber YIM   Вверх
vzf
Дата 14.2.2007, 16:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Все равно не работает.

Код

org.hibernate.QueryException: query must begin with SELECT or FROM: delete [delete from JobLog j where j.jobId = :jobId]


В документации сказано, что в HQL слово from в выражении для delete опционально, поэтому думаю не в этом дело. 

--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
tux
Дата 14.2.2007, 16:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



А версия Hibernate какая?
PM MAIL Skype GTalk Jabber YIM   Вверх
vzf
Дата 14.2.2007, 16:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



использую Hibernate 3.2

Вот вроде бы нашел 
тут
 в чем причина. 

Надо использовать другой (не дефолтный парсер). Попробую разобраться smile
--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
vzf
Дата 14.2.2007, 17:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Изменил конфиг файл для hibernate

вместо 

Код

<property name="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</property>


написал
Код


<property name="hibernate.query.factory_class">org.hibernate.hql.ast.ASTQueryTranslatorFactory</property>


Теперь появляется другое исключение:

Код

org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken [delete JobLog j where j.jobId = :jobId]


Я подключил к проекту файл hibernate3.jar там есть этот класс (HqlToken). Не могу понять в чем дело.    smile 

Причем если в методе я попытаюсь создать экземпляр этого класса ( HqlToken t = new HqlToken(); ), то исключение не выбрасывается.



--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
tux
Дата 14.2.2007, 17:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



А библиотека antlr в CLASSPATH есть?
PM MAIL Skype GTalk Jabber YIM   Вверх
vzf
Дата 14.2.2007, 17:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Я включил библиотеку Antlr-2.7.6.jar в проект (и Ant-antlr-1.6.5.jar докучи). Странно что в том же методе я пишу 
HqlToken t = new HqlToken(); и объект создается. 
--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
tux
Дата 14.2.2007, 17:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



Это объяснить в принципе можно. Hibernate активно использует Cglib для генерации программного кода. Естественно, в этом случае используется свой загрузчик классов, который работает не так как стандартный загрузчик из JDK (или загрузчик веб-контейнера если это веб-проиложение). Отсюда скорее всего и результат. Но вот как это решить пока не знаю.
PM MAIL Skype GTalk Jabber YIM   Вверх
vzf
Дата 14.2.2007, 18:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Может дело в сервере приложений. Я пишу в JDeveloper, соответственно приложение запускается на встроенном OC4J Server'е ?
--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
Armiol
Дата 14.2.2007, 20:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 25.3.2006

Репутация: нет
Всего: нет



Цитата из документации Hibernate:

Цитата

Note that Hibernate does not offer its own API for direct execution of UPDATE or DELETE statements. Hibernate is a state management service, you don't have to think in statements to use it. JDBC is a perfect API for executing SQL statements, you can get a JDBC Connection at any time by calling session.connection(). Furthermore, the notion of mass operations conflicts with object/relational mapping for online transaction processing-oriented applications. Future versions of Hibernate may however provide special mass operation functions. See Chapter 13, Batch processing  for some possible batch operation tricks.


Взято здесь:

http://www.hibernate.org/hib_docs/v3/refer...bjectstate.html

Мне кажется, что стоит подумать, так ли критично использовать explicit query для удаления. Тем более, что Hibernate прямо это запрещает.
PM MAIL   Вверх
vzf
Дата 16.2.2007, 15:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 203
Регистрация: 10.9.2005

Репутация: 2
Всего: 5



Поставил нетбинс с томкатом. Запустил. Работает. Выходит дело в OC4J.
--------------------
Java - Write Once, Test EveryWhere!
PM MAIL   Вверх
tux
Дата 16.2.2007, 15:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 74
Всего: 132



Цитата(vzf @  16.2.2007,  15:01 Найти цитируемый пост)
Поставил нетбинс с томкатом. Запустил. Работает. Выходит дело в OC4J. 

Чудеса.
PM MAIL Skype GTalk Jabber YIM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0814 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.