Структура БД MySql

программирование php MySQL базы данных sql

Получил БД организаций из разных стран. Организации разделены по странам, регионам, городам, и районам. Все гео данные хранятся в отдельных таблицах и имеют след. структуру:

Страны
--------------
| id | name |
--------------

Регионы
------------------------------
| id | id_country | name |
------------------------------

Города
--------------------------------------------
| id | id_country | id_region | name |
--------------------------------------------

Районы
------------------------------------------------------
| id | id_country | id_region | id_city | name |
------------------------------------------------------

Соответственно таблица организаций хранит id каждой гео таблицы:
--------------------------------------------------------------------------
| id_organiz | id_country | id_region | id_city | id_district | ...
--------------------------------------------------------------------------

Все таблицы в InnoDB и внешние ключи на соответствующих полях.
Не очень нравится такая структура таблиц, очень много избыточных данных. Подскажите, как и что можно улучшить?

Примечание:
Если оставлять в каждой таблице {PARENT_AREA_ID}, то может имеет смысл использовать только одну таблицу и представить список городов и стран в виде дерева?

Примечание:
Спасибо за советы, наверное лучше всего воспользоваться советом
>>> По сути реально необходимые поля: id, name, {PARENT_AREA_ID}, где {PARENT_AREA_ID} - если таблица городов - регион, если регион - страна и т.д.

Я сам с самого начала склонялся к такому варианту, но почему то сомневался.
Ответы:
С точки зрения скорости поиска: денормализированная БД (преднамеренно И осознанно) обычно быстрее, но поддерживать такую БД сложнее.
В принципе можете для поиска использовать отдельную таблицу (полностью денормализированную)
>> может имеет смысл использовать только одну таблицу и представить список городов и стран в виде дерева?


10 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.