169 похожих чатов

Доброе утро. Есть ли способ к Eloquent-модели добавлять "динамические" свойства.


К примеру, есть таблица со свойствами (вес, длина, высота), некоторые из которых относятся к некоторым моделям и таблица, которая связывает модели и эти свойства, а также хранит значение.
Вчера советовали eav, но читал про него и многие его называют антипаттерном как минимум из-за n+1.
Никто не знает другого способа, может я что-то упускаю?

11 ответов

7 просмотров

Можешь в json хранить, как вариант.

Shamil 😏- Автор вопроса
Sergey Chizhik
Можешь в json хранить, как вариант.

Думал об этом, но поля должны быть редактируемыми, т.е. пользователь должен иметь возможность переименовать например, вес, на массу и это должно коснуться всех объектов

Так в JSON хранишь по ключам (слагам)

Shamil 😏
Думал об этом, но поля должны быть редактируемыми,...

Название храни отдельно в переводах например, а ключ у свойства не поменяется

Shamil 😏
Думал об этом, но поля должны быть редактируемыми,...

И если у тебя посгря, то JSONB будет достаточно неплохим решением в плане производительности, и (возможно) даже по месту можно не потерять

Shamil 😏- Автор вопроса
Sergey Gerasimov
Так в JSON хранишь по ключам (слагам)

id: 1 name Рулетка properties: {{value: "15 см", slug:"length"},...} и отдельная таблица id: 1 name: length display_name: длина Правильно понял?

Shamil 😏- Автор вопроса
Shamil 😏- Автор вопроса

это не уровен junior, мне кажется для тестового на junior крутовато

Shamil 😏- Автор вопроса
Egor Gruzdev
это не уровен junior, мне кажется для тестового на...

А, ну так это не для меня задание. Я просто беру задания из интернета и делаю их, тут ценность в опыте и в том, чтобы набить руку, устраиваться туда я не собираюсь

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
доброго времени. db, dw и прочие исполняются при трансляции или при выполнении программы?
lutayyy
10
Почему никто не подсказал, что можно объявить свои типы данных, в которых меньше полей, чем в отданном джейсоне, и добавлять их по необходимости?
Strange Rabbit
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Карта сайта