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

Всем привет кто как решает проблему с когда у таблицы

должна быть связь с несколькими другими, но одной?

К примеру уведомления. Создаете несколько таблиц m2m, несколько полей с fk ключом или что-то другое?

7 ответов

8 просмотров

Привет! Опиши не абстрактно, а конкретный пример. Так будет проще подсказать.

Matvei-Bekishev Автор вопроса
Ilya Zelenchuk
Привет! Опиши не абстрактно, а конкретный пример. ...

Ну уведомления могут быть о выходе поста, коментария, сообщения и тп. А и при подробнее открывать пост, коментарий...

Matvei Bekishev
Ну уведомления могут быть о выходе поста, коментар...

Как решение в лоб. 1. Сделай в таблице с уведомлениями связь сразу с несколькими таблицами. 2. Добавь в таблицу с уведомлениями поле тип. 3. В зависимости от типа заполняй соответствующую связь. Например: class Post (db.Model): id = db.Column(db.Integer, primary_key=True) text = db.Column(db.String(512), nullable=False) class Comment (db.Model): id = db.Column(db.Integer, primary_key=True) comment = db.Column(db.String(512), nullable=False) class Notifications (db.Model): id = db.Column(db.Integer, primary_key=True) notification_text = db.Column(db.String(512), nullable=False) post_id = Column(Integer, ForeignKey('post.id')) comment_id = Column(Integer, ForeignKey('comment.id')) type = db.Column(db.Integer, nullable=False, default=0) как-то такая идея.

Matvei-Bekishev Автор вопроса
Ilya Zelenchuk
Как решение в лоб. 1. Сделай в таблице с уведомлен...

в принципе этот вариант будет проще, при новой сущности создаётся просто новая колонка

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
62
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
а где есть mysql cloud кроме яндекс-клауд?
Oleg Nosov
13
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
13
hi im a cs student. i need some advice from people who have enough experience in Embedded Software. I need to know whether this profession is suitable for me. I have watched s...
Sahand 🏔️
8
use16 org 0x7c00 mov bx, msg call print jmp $ print: pusha start: mov ah, 0x0e mov al, [bx] cmp al, 0 je end ...
sans
4
Кстати а покупал кто-нибудь ЭЦП для подписи кода? А то у меня на некоторых компах и ОС иногда SmartScreen винды программу за вирус принимал. Если купить такую ЭЦП и подписыват...
Дмитрий Завгородний
15
А кто-нибудь запихивал сборку перловых модулей/образов с perl приложениями в окружения без интернета (в специализированном CI/CD)? У меня сейчас есть ряд cpanfile, которые н...
Andrey Smirnov / 𝓪𝓵𝓵𝓽𝓮𝓻 /
14
Карта сайта