Всем привет, вопрос по архитектуре БД У меня есть продукты и

бренды, они заносятся с разных маркет плейсов (wb, ozon)

Хочу отказаться от идентификаторов (id, autoincrement)

Хорошая ли практика делать primary key составной из двух полей:
external_id - внешний идентификатор продукта/бренда на площадке
platform_id - идентификатор площадки

И так, есть две таблицы:
- Бренды:
- name
- external_id
- platform_id
- Продукты:
- external_id
- platform_id
- brand_id (external_id из таблицы brands)
- name

То есть это выглядит примерно так:
CREATE TABLE brands (
name VARCHAR(255),
platform_id INT,
external_id INT,
PRIMARY KEY (external_id, platform_id),
);

CREATE TABLE products (
external_id INT AUTO_INCREMENT,
name VARCHAR(255),
platform_id INT,
brand_id INT,
PRIMARY KEY (external_id, platform_id),
FOREIGN KEY (brand_id, platform_id) REFERENCES brands (external_id, platform_id)
)

Идентификаторы (внешние идентификаторы) внутри одной площадки всегда уникальные.

Хочу услышать мнение более опытных людей, может что-то посоветуете получше?

5 ответов

52 просмотра

А почему бы просто не вкрячить все в один столбец? Первая цифра будет указывать на маркетплейс условно, все остальные цифры - уникальный айдюк. Правда все равно хочется отдельный столбец для быстрого поиска вещей по конкретному маркету без использования like

为什么要翻译-. Автор вопроса
Vladislav Sh.
А почему бы просто не вкрячить все в один столбец?...

Именно поиск будет по названию через эластик, если в один столбец, то там PrimaryKey будет char, думаю на типе INT будет быстрее работать

Ничего плохого тут нет.

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта