Приветствую. Подскажите в какую сторону посмотреть для полиморфизма сущностей? Кейс:

есть сущность, у сущности есть тип, в зависимости от типа разное поведение на одних и тех же методах. Напрашивается разделение на классы.
Single Table не подходит, из-за кейса изменения типа (изменение только через запрос сработает) + при создании надо создавать конкретные дочерние сущности, т.е. тоже не очень выглядит.
Либо внутри сущности вводить стратегии под каждый тип, но тогда полная анемия.
Может еще какие варианты есть?

15 ответов

26 просмотров

каждой сущности своя таблица ? у вас же они разные даже по поведению, значит по сути это разные вещи

Павел-Г. Автор вопроса
Dmitry
каждой сущности своя таблица ? у вас же они разные...

Одна таблица. Так как есть констрейнт на идентификатор, ну и в целом это скорее одна сущность по бизнесу.

Павел-Г. Автор вопроса
Dmitry
mapped superclass может тогда ?

Не подходит, мне нужно не зная типа, получить по идентификатору некую сущность и чтобы она прилетела нужного класса. Как то так)

Павел Г.
Не подходит, мне нужно не зная типа, получить по и...

"не зная типа" vs "нужного класса" это как? да и что за кейс такой? юзеру плевать какого типа там сущность, у него есть цифра и он с цифрой что-то делает?

Павел-Г. Автор вопроса
Dmitry
фабрику тогда организуйте

Какую и как? Мне надо сущности получить, которые будут в UOF.

Павел Г.
Верно

выглядит странно

Павел Г.
Не подходит, мне нужно не зная типа, получить по и...

ну чисто как вариант, хотя не уверен что взлетит Entity достается доктриной как обычно Entity::convertToType(match $this->type): self ChildEntity extends Entity

Павел-Г. Автор вопроса
Шурик
"не зная типа" vs "нужного класса" это как? да и ...

Есть базоваяСобака, есть БольшаяСобака, МаленькаяСобака. Ну и пусть будет метод "рычать" и они делают это по разному. При этом сам код не должен знать какая именно сейчас собака прилетела из репозитория. Кейс работает на Single Table но другие кейсы (изменение типа) - не очень.

Павел Г.
Есть базоваяСобака, есть БольшаяСобака, МаленькаяС...

а юзер с кем взаимодействует? он не знает?

Павел-Г. Автор вопроса
Шурик
а юзер с кем взаимодействует? он не знает?

Он с Базовой собакой, у которой есть интерфейс "рычать" )

Павел Г.
Он с Базовой собакой, у которой есть интерфейс "ры...

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

Павел-Г. Автор вопроса
Шурик
а почему тогда собака разбита на три типа? пусть п...

Тогда тут вариант куча методов с switch case. Что напрашивается на рефакторинг. Рефакторить можно в 2 направление - на три собаки, или делать 1 анемичную собаку а внутри нее 3 стратегии

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта