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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Не работает каскадное удаление 
V
    Опции темы
Joss
Дата 9.9.2009, 18:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Доброго времени суток!
Столкнулся со следующей проблемой. Есть сущность Событие:
Код

@Entity
@Table(name="JTMEvent")
public class Event implements Serializable {
    private static final long serialVersionUID = 1L;

    // ...

    @ManyToOne
    @JoinColumn(name = "ParentEventRef")
    private Event parent;

    @OneToMany(mappedBy = "parent", cascade={CascadeType.REMOVE, CascadeType.PERSIST})
    private Collection<Event> subEvents;

    // ...
}


Бин, реализующий управление событиями
Код

@Stateless
public class EventsManagerBean implements EventsManager {
    @PersistenceContext
    private EntityManager em;

    public void dropEvent(String eventId) throws InvalidParametersException {
        Event event = em.find(Event.class, eventId);
        if (event == null) {
            throw new InvalidParametersException("Event " + eventId + " wasn't found");
        }

        em.remove(event);
    }
}


В результате выполнения этого метода возникает ошибка JDBC-драйвера используемой бд: Dependent foreign key constraint violation in a referential integrity constraint. Это происходит в случае, когда удаляемое событие содержит "под-события", хотя по идее  CascadeType.REMOVE должен обеспечить и их удаление тоже.

Сервер - Glassfish 2.x, провайдер - TopLink. 

Есть подозрение, что проблема каким-то образом связана с кешированием в TopLink, т.к. при его отключении такой проблемы не возникает.

Какие мысли по поводу?


PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "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.0989 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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