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

Как правильно хранить в бд данные классов-наследников? ну вот условно, если

у меня класс животных
Там есть жираф и кукуха
У них есть пара разных полей, но в коде я работаю с ними как с Животными (базовый класс)
соответсвенно мне из бд надо тянуть именно Животных, но чтоб количество крыльев у кукухи условно все-таки сохранилось

Как такое можно решить?
Делать репозиторий животных, и внутри него тянуть в два запроса с Кукухи и Жирфа?
Мне не очень нравится такое решение, ибо оно херово расширяется, верю что есть варианты получше

Возможно тупо сформулировал, но я в вас верю, вы поймете
если что, го уточню

15 ответов

17 просмотров

1к1

Барсик- Автор вопроса

Ну есть подходы таблица на класс и таблица на иерархию, это и гуглить как в еф задать

Тебе стоит уточнить в каком типе бд ты собираешься это хранить

Барсик
Любая скл бд

Не читал следующие 400+ сообщения, может тебе уже чета дельное насоветовали, но я похожее решал так: есть просто одна таблица с базовыми полями и указанием какого типа запись и дальше связь 1 ко многим, где указаны свойства и значения дополнительных данных. Гибко в плане расширения. Есть еще вариант плоской таблицы, которая будет содержать все поля всех наследников, но селект из базы будет происходить только по нужным полям, но это для небольших моделей еще имеет смысл

1) юзать монгу как отдельный сервис 2) юзать постгрес где есть возможность хранить и работать с json 3) юзать постгрес - есть возможность наследовать таблицы + к тому, что уже сказали

Alex
а почему 1 к многим?

Во второй таблице у тебя 1 запись на каждое свойство, грубо говоря внешний ключ на основную, поле и его значение

попробуй подход Table per Hierarchy

Барсик- Автор вопроса
Владислав
попробуй подход Table per Hierarchy

угу, уже посоветовали его, спасибо)

Віталій EasyMod
Во второй таблице у тебя 1 запись на каждое свойст...

уф, а почему не 1к1? просто отдельные таблицы для каждого типа

Alex
а почему 1 к многим?

Например так удобно датчики от гпс трекера хранить - в основной координаты, время скорость, а в дополнительной уже разные датчики типа уровня топлива, напряжения акума и тд, везде по разному в разной технике

Віталій EasyMod
Например так удобно датчики от гпс трекера хранить...

а, окей, то есть у тебя нет конкретных классов

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

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

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Использую кастомное модальное диалоговое окошко, все по классике - mrOK, mrCancel как ModalResult. Однако есть нюанс - в главной форме есть универсальный обработч...
Олег Гранишевский
20
Карта сайта