我在正确设置中间件和路由器以支持多个数据库时遇到问题,每种语言一个(我决定将它们分开)。
我尝试使用this solution,但是到目前为止,我并没有太多使用它。
在我的 settings.py 中,数据库和中间件的定义如下:
DATABASES = {
'default': {},
'ru': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'db_ru.sqlite3',
},
'en': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'db_en.sqlite3',
}
}
DATABASE_ROUTERS = ['me.middleware.database_routing.DatabaseRouter']
MIDDLEWARE = [
'me.middleware.database_routing.RouterMiddleware',
'django.middleware.security.SecurityMiddleware',
'whitenoise.middleware.WhiteNoiseMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.locale.LocaleMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
'me.middleware.database_routing'
中使用的database_routing.py 完全对应于this middleware。
启动服务器时出现错误: RouterMiddleware()不接受任何参数。我相信中间件代码存在一些缺陷。另外,我无法迁移到数据库,我得到了ValueError: Cannot assign "<ContentType: ContentType object (1)>": the current database router prevents this relation.
也许还有其他解决方法?
答案 0 :(得分:0)
如果您的database_routing.py包含以下部分,则它将停止在Django中创建的关系。
因此,请尝试在注释行中添加注释,仅返回true。 这对我有用!
def allow_relation(self, obj1, obj2, **hints):
"""
Do not allow relations involving the remote database
"""
# print("in allow relation")
# if obj1._meta.app_label == Organization or \
# obj2._meta.app_label == Organization:
# return True
# return None
return True