Задать вопрос
@phpcoder81

Как правильно указать внешний ключ InnoDB?

Ребят, наткнулся на проблему. Есть таблица "заказы". В ней есть поле USER. Это внешний ключ к полю таблицы `users`.`id`. Все дело в том, что иногда заказ можно оформить НЕ зарегистрированному пользователю. В этом случае в поле USER хотелось бы поставить 0. Но тк нет такого ID то MYSQL ругается. Остаются решения:
1) НЕ СОЕДИНЯТЬ эти таблицы внешним ключом.
2) Я еще подумал, создать таблицу пользователей, и в ней указать номер 1 как "na". В этом случае тоже все получается.
  • Вопрос задан
  • 420 просмотров
Подписаться 1 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillbox
    Python-разработчик
    10 месяцев
    Далее
  • ProductStar
    Профессия: Java-разработчик
    9 месяцев
    Далее
  • GB (GeekBrains)
    Профессия Python-разработчик
    10 месяцев
    Далее
Решения вопроса 2
qonand
@qonand
Software Engineer
достаточно полю присвоить значение NULL если заказ оформляет не зарегистрированный пользователь
Ответ написан
Комментировать
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

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