Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Django: database, relation, many to many, orm

Как связать модели "Магазин" и "Книга" (если книга есть в нескольких магазинах)?

Проверяет знание типов связей в реляционных базах данных и их реализацию в Django ORM.

Короткий ответ

Если книга может быть в нескольких магазинах, а магазин содержит много книг — это связь «многие ко многим» (ManyToMany). В Django её реализуют через ManyToManyField. При этом создаётся промежуточная таблица, которая хранит пары «магазин-книга».

Длинный ответ

Связь «многие ко многим» используется, когда:

  • Один объект (книга) принадлежит нескольким объектам (магазинам).

  • Один объект (магазин) содержит много объектов (книг).

Реализация в Django:

class Book(models.Model):
    	title = models.CharField(max_length=100)

class Shop(models.Model):
    	name = models.CharField(max_length=100)
    	books = models.ManyToManyField(Book)  # Связь!

# Теперь можно делать:
shop = Shop.objects.get(name="Лабиринт")
shop.books.add(Book.objects.get(title="Гарри Поттер"))  # Добавить книгу

Как это работает в БД:

  1. Django автоматически создаёт таблицу shop_books с колонками:

    • id (первичный ключ)

    • shop_id (внешний ключ на магазин)

    • book_id (внешний ключ на книгу)

  2. Запросы для получения всех книг магазина:

    shop.books.all()  # Все книги конкретного магазина
    book.shop_set.all()  # Все магазины, где есть книга

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

class Stock(models.Model):
    	shop = models.ForeignKey(Shop, on_delete=models.CASCADE)
    	book = models.ForeignKey(Book, on_delete=models.CASCADE)
    	quantity = models.IntegerField()  # Доп. поле

class Shop(models.Model):
    	books = models.ManyToManyField(Book, through='Stock')  # Через Stock

Вывод:
ManyToManyField — стандартный способ для сложных связей.

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    2

  • Сложность:

    6

Навыки

  • Django

    Django

Ключевые слова

#database

#relation

#many to many

#orm

Подпишись на Python Developer в телеграм

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.