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
Пожалуйста, кто-нибудь может помочь мне с этим или, по крайней мере, сообщить мне о лучшем способе достижения того, что я пытаюсь сделать?
Любая помощь будет очень признательна.