Форум программистов, компьютерный форум, киберфорум
PHP: ООП
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 22.01.2019
Сообщений: 14

Удаление сущностей active record

18.02.2019, 10:58. Показов 2086. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем хай! Опять я с тупым вопросом! Вот есть у меня класс Product (сущность - active record) и есть такие же ProductImage, ProductComment и все такое.

1) надо сделать так чтобы при удалении ProductImage удалялся файл. Я подсмотрел что некоторые делают у сущности функцию beforeDelete и в ней удаляют файл. А кто то говорит что надо сделать типа сервис ProductManager и через него удалять. А как правильно то?
2) продолжение первого - хочу при удалении Product удалять все соответствующие ProductImage, ProductComment и т.п., ну и файлы картинок тоже должны удаляться. А эту штуку как правильно делать? Варианты вроде в голову приходят, но интересно как делает народ.

Пасиба!

Добавлено через 27 минут
А! пока не забыл, хотел еще спросить про записи в тех таблицах где нет сущностей activerecord, например всякие характеристики и тп. Их как правильно удалять при удалении Product?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.02.2019, 10:58
Ответы с готовыми решениями:

Active Record vs Data Mapper
Часто встречаю в интернете такую точку зрения что Active Record это зло и Data Mapper луче, за что многие ругают такие фреймворки как...

Асссоциации Active Record
Тут уже было что-то похожее но я все таки спрошу. Есть две таблицы связанные ассоциацией один ко многим. project.rb class...

Active Record - Reference to Fields
Здравствуйте. Есть таблица User: id login passwd Нужно создать таблицу Transactions, в которой 2 поля должны быть внешними...

5
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
18.02.2019, 11:50
Лучший ответ Сообщение было отмечено stupidnoob как решение

Решение

Удалять через сервис. Все эти beforeDelete, afterUpdate и т.д даже по меркам active record говнокод.
1
0 / 0 / 0
Регистрация: 22.01.2019
Сообщений: 14
18.02.2019, 14:27  [ТС]
пасиба! я правильно понял идею?

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
class ProductManager{
    public function deleteProductById($id){
      # получаем и удаляем comments и images через функции ниже, затем сам товар
    }
 
    public function deleteImageById($id){
        # удаляем картинку
    }
 
    public function deleteCommentById($id){
        # удаляем коммент
    }
}
Добавлено через 1 час 58 минут
не, громоздко выходит
PHP
1
2
3
4
5
6
7
8
9
10
11
12
createProduct
getProductById($id)
getProductByArticle($article)
updateProduct($params, $id)
deleteProduct($id)
importProduct([]) //'массив с кучей параметров,чтобы одной функцией создать товар с картинками и тп.'
 
createImage($product_id, $path)
getImageById($id)
getImagesByProductId($id)
deleteImageById($id)
deleteImagesByProductId($product_id)
и т.д.

А если для каждой сущности свой сервис и еще сверху фасад, через который все эти функции сразу доступны? норм вариант?
0
209 / 191 / 49
Регистрация: 15.03.2016
Сообщений: 1,230
23.02.2019, 12:51
можно создать таблицу с сущностями, в которой перечислять операции при любом CRUD
+больше шаблонов
не надо под каждый чих свой Delete лепить. DELETE это типовая операция, там только название таблицы и колонки поменять.
0
0 / 0 / 0
Регистрация: 22.01.2019
Сообщений: 14
19.03.2019, 20:13  [ТС]
это да, но тут как раз нетиповые операции. при удалении картинки надо удалить и запись из бд и файл. при удалении товара удалить и товар из бд, и картинки (бд и файлы), характеристики, и кучу всего еще. для простых ситуаций конечно я просто делаю Сущность::deleteById($id) и готово.
0
209 / 191 / 49
Регистрация: 15.03.2016
Сообщений: 1,230
20.03.2019, 11:42
для этого есть foreign key
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.03.2019, 11:42
Помогаю со студенческими работами здесь

Связи (ассоциации) Active Record.
Имеются 3 таблицы. User(devise), questionnaire і question. Связь user=questionnaire і questionnaire=question настроены. Как настроить...

Active Record при нескольких таблицах
Можете подсказать допустим есть пост вот его таблица POST id title slider - это id на запись в таблице sliders

Удаление одной из one-to-one сущностей
Добрый день. У меня есть вопрос по работе со связанными один-к-одному сущностями: если я ставлю каскад all, то удаляются обе при удалении...

Удаление Active directory
хотел удалить AD, но не получается. Выходить такая ошибка: Active directory нельзя удалить с этого контроллера домена, поскольку это...

Удаление Active Directory
На Win Server 2003 надо поставить одну клиент-серверную прогу, но при установке MySQL один из компонентов ругается на то, что на ЭВМ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru