юзера может быть много объектов travels. Каждый travels уникален и никогда не повторяется ни у юзера ни у других юзеров.
{
"user_name":"Jon_12",
"first_name":"Jon",
"last_name":"Getsby",
"user_id":2438207,
"travels" : {
"type":"Vacation",
"id":1,
"city":[
"Toronto",
"Sidney"
],
"rivers":[
"Missisipy",
"Amazonka"
],
"comment":true,
"good":[
"good people",
"good weather"
],
"bad":[
"expensive",
"long away"
]
}
}
Я понимаю, что будет табличка _users и табличка _travels и у _users будет связь с _travels.
Не пойму как организовать _travels...
1. Как табличку в которой будут лежать отдельные объекты по ключам-id юзера?
2. Или как наборы объектов _travels которые будут лежать внутри массива по ключу юзера...
В первом случае, при выдаче данных пользователя нужно будет выбирать из _travels все объекты по id пользователя и джоинить к основным данным...
Во втором случае, брать в _travels массив с объектами по id-ключу юзера...
Как будет правильно и оптимизированно?
Придумывать таблицы по структуре json-а - плохая идея. Надо отталкиваться от логики бизнесовых требований, а также источников данных, которые у вас будут. Вот у вас там есть списки топонимов, разделённые по типам. Может быть, это должна быть таблица-справочник топонимов с типизацией + таблица связи многие-ко-многим с travels. Отдельно, видимо, будет таблица положительных и отрицательных моментов в связке с travels. И тут может быть как зависимая таблица, так и справочник + связь. Но опять же, у вас может быть бизнес-требование, которое сделает такую схему жутко неудобной. Кстати, зачем вы добавляете _ в начало имени таблицы? Это очень странно смотрится. Уж лучше делать общий для таблиц всего проекта префикс.
Хм .. Про таблицу с топонимами я подумаю. Ценное замечание... Нижний префикс почему-то добавляет ОРМка .. Я уже привык к этому .)
JSON в БД - это MongoDB.
Мне нужен Постгрес. ) С Монго я бы таких вопросов не задавал.
Да сделайте Вы обычные нормализованные таблицы (какие — Вам виднее, по одному примеру не скажешь), что тут думать? ;)
Забавно, а я-то думал, что, цитирую, "монга должна умереть", и появление jsonb - один из чекпоинтов на пути к этому
Я когда шучу смайлики не всегда ставлю.
Когда в Постгрес и вообще в базы данных только третий день вникаешь - есть о чём думать... )
Обсуждают сегодня