![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
Gwendolen |
|
||||||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 119 Регистрация: 5.4.2005 Репутация: нет Всего: 1 |
Возникли некоторые вопросы при миграции давно работающего проекта с MyISAM на InnoDB.
Есть множество таблиц с различными параметрами(обычно вариантов для выпадающих списков) вот такого вида:
Они редактируются очень редко(преимущественно из админки) и используются во множестве других таблиц:
Понятно что лучше переводы делать в отдельных таблицах. Но после добавления внешних ключей такого вида:
После беглого тестирования проблем не нашел и вроде всё устраивает. Если в таблицу `information` внесена ссылка на `type`, то из таблицы `type` я не могу удалить ни одного связанного преревода, даже если это не последний перевод для данного типа. Вообще-то это запрещается и логикой при редактировании, но я пытался удалить из БД напрямую. Большого желания менять нет. Но пока происходит глобальный рефакторинг можно бы было(но не желательо) выделить недельку на изменение и тестирование в этой части. Какие вообще могут поджидать проблемы если оставить подобную схему БД? Или все-таки это рабочий вариант? P.S. Благодаря внешним ключам нашел много потерянных и даже немного несогласованных данных. Это сообщение отредактировал(а) Gwendolen - 16.9.2022, 06:51 --------------------
Наносите пользу и причиняйте добро! |
||||||
|
|||||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Да вполне себе рабочий вариант. Внешние ключи - средство как бы проверенное и временем, и кучей разработчиков.
Где транзакции, там и дедлоки. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
![]() ![]() ![]() |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |