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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Изменить значение дискриминатора 
:(
    Опции темы
barracuda477
Дата 11.1.2009, 16:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Юзаю хибернейт. 
Есть иерархия классов, сущности записываются "table per class hierarchy" (то есть всю иерархию в одну таблицу).

Отличие классов - только в значении самого дискриминатора.

Задача - мне нужно изменить значение дискриминатора, чтобы  при последующем чтении получить другой класс по изменённой записи.
Проблема - при апдейте хибренейт не изменяет значение дискриминатора ни при каких условиях (то есть сгенерированный SQL не содержит изменение поля дискриминатора). 
Пробовал в том числе создавая сущность другого класса из иерархии и копируюя в неё данные из первой сущности с последующим апдейтом созданной сущности другого класса.

Порылся в вебе, есть 2 варианта:
1) удалить старую сущность (удалить запись из таблицы), вставить новую с другим классом
2) выполнить свой update-SQL для апдейта значения дискриминатора вручную

Никаких вариантов получше нет?

PM MAIL   Вверх
ecologist
Дата 12.1.2009, 09:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



1 вариант - наиболее корректный с точки зрения работы с данными. Как я понимаю копируем нужные поля и потом уже удаляем и добавляем.
2 вариант - возможны проблемы из-за кэширования - я бы не рискнул бы его использовать.

3 вариант - вимательнее посмотреть на проектирование - с чего это вдруг надо менять класс объекта.

PM MAIL   Вверх
MisterCleric
Дата 12.1.2009, 09:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

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



Цитата

3 вариант - вимательнее посмотреть на проектирование - с чего это вдруг надо менять класс объекта.


Абсолютно согласен.
Может просто стоит создать сущность другого типа по образу и подобию и положить в таблицу? а старую можно и грохнуть...

to barracuda477 приведите пример логики, в связи с которой возникла такая задача


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
barracuda477
Дата 14.1.2009, 01:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата

1 вариант - наиболее корректный с точки зрения работы с данными. Как я понимаю копируем нужные поля и потом уже удаляем и добавляем.

можно, но primary key в этой таблице является forein key в другой. Как бы не хорошо удалять, cascade пока не стоит, но как-то душа у меня не лежит smile

Цитата

2 вариант - возможны проблемы из-за кэширования - я бы не рискнул бы его использовать.

кеширования кем ? СУБД или хибернейтом ?
Кеш СУБД тут проапдейтится, для СУБД нет разницы от кого пришел запрос
Если имеется ввиду кеш Хибернейта - то Хибернейт должен учитывать, что некоторые запросы могут ити мимо него вообще, то есть совсем с другого клиента.

Цитата

3 вариант - вимательнее посмотреть на проектирование - с чего это вдруг надо менять класс объекта.

да, согласен, резонно

почему вздумалось менять ? Опишу архитектуру/логику.

Есть некие параметры. Они составлены в дерево. Соответсвенно, некоторые параметры абстрактные (узлы дерева) - по ним нет никаких значений. По параметрам-листьям есть значения. 
Понятно, что в классах параметры со значениями наследуются от абстракных параметров, имея свою логику (например логика проверки значений парамеров, типа параметры попадают в какой-то диапазон и т.д.)

Почему нужно менять класс ? Дерево параметров было набито руцями, то есть дискриминаторы были изначально неверно проставлены - захотелось сделать возможность редактировать эти параметры. Но прихожу к выводу что это будет overengineered, т.к. проставить дискриминаторы можно и руцями, а в дальнейшем оно будет совсем-совсем нечасто меняться.
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.0848 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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