Django - Использование нескольких баз данных для одного проекта

Я работаю над системой бронирования с использованием фреймворка Django. Мне нужно создать два проекта (веб-сайт и административный сайт для регистрации персонала и управления системой бронирования). Я хочу использовать SQLite3 для данных сессии и других таблиц/данных, требуемых Django, и использовать базу данных MySQL для связи двух проектов вместе. Я хочу иметь возможность устанавливать доступные даты для бронирования через администраторский сайт, которые будут отображаться на сайте, чтобы люди могли сделать заказ.

Я пробовал несколько способов сделать это, но, похоже, ничего не помогает.

settings.py

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    },
    'theRock_db': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'theRock',
        'USER': '<Database Username>',
        'PASSWORD': '<Database User Password>',
        'HOST': '<Database Host>',
        'PORT': '<Database Port>',
    }
}

DATABASE_ROUTERS = ['routers.db_routers.theRockRouter',]

db_routers.py

class theRockRouter:

    route_app_labels = ['theRockAdminAccounts',]

    def db_for_read(self, model, **hints):
        if model._meta.app_label in self.route_app_labels:
            return 'theRock_db'
        return None

    def db_for_write(self, model, **hints):
        if model._meta.app_label in self.route_app_labels:
            return 'theRock_db'
        return None

    def allow_relation(self, obj1, obj2, **hints):
        if (
            obj1._meta.app_label in self.route_app_labels or
            obj2._meta.app_label in self.route_app_labels
        ):
           return True
        return None

    def allow_migrate(self, db, app_label, model_name=None, **hints):
        if app_label in self.route_app_labels:
            return db == 'theRock_db'
        return None

models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser, BaseUserManager, PermissionsMixin

class UserManager(BaseUserManager):
    def create_user(self, username, email, password=None, **kwargs):
        if not username:
            raise ValueError("Username is a required field")
        if not email:
            raise ValueError("Email is a required field")
        user = self.model(username=username, email=email)
        user.set_password(password)
        user.save()
        return user

    def create_superuser(self, username, email, password=None, **kwargs):
        user = self.create_user(username=username, email=email, password=password, **kwargs)
        user.is_staff = True
        user.is_superuser = True
        user.save()
        return user

class User(AbstractBaseUser, PermissionsMixin):
    username = models.CharField(max_length=150, unique=True)
    email = models.EmailField(max_length=150, unique=True)
    first_name = models.CharField(max_length=150)
    last_name = models.CharField(max_length=150)

    date_joined = models.DateTimeField(auto_now_add=True, null=True)
    last_login = models.DateTimeField(auto_now=True, null=True, blank=True)

    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)

    objects = UserManager()

    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['email']

    def __str__(self):
        return self.username

Когда я использую этот метод, я получаю ошибку no such table. Даже если я мигрирую команды:

python manage.py migrate

(and)

python manage.py migrate --database=theRock_db

Project traceback

├── env
├── manage.py
├── routers
│   ├── __pycache__
│   │   └── db_routers.cpython-39.pyc
│   └── db_routers.py
├── theRockAdmin
│   ├── __init__.py
│   ├── __pycache__
│   ├── asgi.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── theRockAdminAccounts
    ├── __init__.py
    ├── __pycache__
    ├── admin.py
    ├── apps.py
    ├── migrations
    │   ├── 0001_initial.py
    │   ├── __init__.py
    │   └── __pycache__
    ├── models.py
    ├── tests.py
    └── views.py

Пожалуйста, кто-нибудь может помочь мне с этим или, по крайней мере, сообщить мне о лучшем способе достижения того, что я пытаюсь сделать?

Любая помощь будет очень признательна.

Вернуться на верх