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

Всем привет) Есть таблица users и data Предполагается, что у каждого юзера

может быть несколько строчек из data
В таком случае же делается отдельная таблица для связки users => data?
Какой тогда primary key будет? Он же должен быть уникальным.
А тут один юзер будет иметь несколько строк с data.id

Или сделать наоборот
Primary key == data.id?

Какая практика вообще в таких случая приветствуется?
Cпасибо)

12 ответов

17 просмотров

отдельная таблица — это многие-ко-многим. в вашем случае достаточно в data добавить колонку user_id

на data_users будет композитный primary key например, если не добавлять дпоолнительных полей

Mikhail-Smolnikov Автор вопроса
Виктор Егоров
отдельная таблица — это многие-ко-многим. в вашем ...

Хорошо, а если предположим, что несколько юзеров будут иметь одну и ту же data?

Mikhail Smolnikov
Хорошо, а если предположим, что несколько юзеров б...

это дополнительное условие, или же полностью новое?

Mikhail-Smolnikov Автор вопроса
Mikhail-Smolnikov Автор вопроса
Dmitriy Sviridov
Поле data_id в таблице users

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

Mikhail Smolnikov
Грубо говоря каждый раз перед созданием data прове...

Можно не проверять даже, достаточно внешний ключ повесить - PostgreSQL сам проверит

Mikhail Smolnikov
это который foreign key?

Да. Но, судя по тому, что вы выше написали "Первоначально заложить и такую возможность" - вам нужно всё же m2m

Mikhail-Smolnikov Автор вопроса
Dmitriy Sviridov
Да. Но, судя по тому, что вы выше написали "Первон...

т.е через отдельную реляционную таблицу?

Mikhail Smolnikov
т.е через отдельную реляционную таблицу?

Да, но даже так внешние ключи, естественно, нужны

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта