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

Решил посоветоваться насчет работы с айдишниками в постгрес. В базе

у каждой таблицы есть сразу два поля: id, external_id. Первый autoincrement, а второй UUID4. Кроме того поле id является PK, тогда как external_id нет. Теперь появился сценарий, в котором нужно создать запись в M2M табличке. Эта табличка ссылается на две других. Таким образом встает вопрос к какому полю делать Foreign Key:
1. Сделать Foreign Key на id. В таком случае это правильно с точки зрения построения БД, но непонятно как это хендлить на уровне приложения если пользователь посылает мне UUID.
2. Сделать Foreign Key на external_id. Это идея вообще не нравится.
Может есть какой-то общий подход в данной ситуации?

2 ответов

10 просмотров

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

Murad-Akhundov Автор вопроса
Sergey P
Назвал их внешними - значит внешние. Переводи во в...

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

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

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

generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Хотел уточнить: копирование из одного рекорда в другой однотипный рекорд можно только по полям отдельно или можно чохом, типа Assign?
Ed Doc
9
Похоже опять туплю задача https://stepik.org/lesson/5431/step/8?unit=1132 код и его работа https://play.haskell.org/saved/lmYTShXM на мой взгляд все правильно, и даже избыто...
Fedor
8
что-то я не понимаю, в линуксе отладочную информацию как убрать из бинаря? он что с этой опцией, что без - одного и того же (достаточно большого) размера (да, я про лазарь)
Iluha Companets
13
Hey Does anyone know how can I receive push notifications from Github on my account? The official Github android app doesn't send notifications, and I don't use the email bec...
Jacob
10
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
вопрос: кто как решает вопрос с динамической подгрузкой скриптов для отдельных страниц с включенным turbo router?
Sergei Toroptsev
25
Как в webstorm включить фичу, чтобы прямо в коде можно было видеть кто редактировал это строчку и в каком коммите?
Антон
8
Карта сайта