Django app配置多個數(shù)據(jù)庫代碼實例
這篇文章主要介紹了Django app配置多個數(shù)據(jù)庫代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
每個app使用不同的數(shù)據(jù)庫
1. 配置數(shù)據(jù)庫連接
# settings.py # DATABASES中必須要有default字段 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db', 'USER': '', 'PASSWORD': '', 'HOST': "localhost", 'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'} }, 'db1': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db1', 'USER': '', 'PASSWORD': '', 'HOST': "localhost", 'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'} } }
2. 配置數(shù)據(jù)庫路由
# settings.py DATABASES_APPS_MAPPING = { 'app1': 'default', 'app2': 'db1', } DATABASE_ROUTERS = ['utils.database_router.DatabaseAppsRouter']
3. 數(shù)據(jù)庫路由文件:
from django.conf import settings class DatabaseAppsRouter(object): def db_for_read(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: return settings.DATABASES_APPS_MAPPING[app_label] return None def db_for_write(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: return settings.DATABASES_APPS_MAPPING[app_label] return None
至此,使用app1的model會訪問default數(shù)據(jù)庫,使用app2的model會訪問db1數(shù)據(jù)庫
同一個app下使用不同數(shù)據(jù)庫
只需要在model class中修改app_label的值即可,app_label默認為此model所在app的名稱
class Book2(models.Model): author = models.CharField(max_length=1024, blank=True, null=True) title = models.CharField(max_length=1024) class Meta: app_label = 'db1'
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 詳解多線程Django程序耗盡數(shù)據(jù)庫連接的問題
- Django使用多數(shù)據(jù)庫的方法
- Django中數(shù)據(jù)庫的數(shù)據(jù)關系:一對一,一對多,多對多
- django 多數(shù)據(jù)庫配置教程
- Django多數(shù)據(jù)庫配置及逆向生成model教程
- django 多數(shù)據(jù)庫及分庫實現(xiàn)方式
- django 鏈接多個數(shù)據(jù)庫 并使用原生sql實現(xiàn)
- Django多數(shù)據(jù)庫的實現(xiàn)過程詳解
- Django多數(shù)據(jù)庫聯(lián)用實現(xiàn)方法解析
- django使用多個數(shù)據(jù)庫的方法實例
相關文章
python+Splinter實現(xiàn)12306搶票功能
這篇文章主要為大家詳細介紹了python+Splinter實現(xiàn)12306搶票功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09Python實現(xiàn)刪除文件中含“指定內(nèi)容”的行示例
這篇文章主要介紹了Python實現(xiàn)刪除文件中含“指定內(nèi)容”的行功能,涉及Python針對文件讀取及字符串遍歷、判斷等相關操作技巧,需要的朋友可以參考下2017-06-06html網(wǎng)頁調(diào)用后端python代碼的方法實例
html頁面中確實能夠調(diào)用python程序,不過只能調(diào)“一點點”,下面這篇文章主要給大家介紹了關于html網(wǎng)頁調(diào)用后端python代碼的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-01-01簡單了解Python3 bytes和str類型的區(qū)別和聯(lián)系
這篇文章主要介紹了簡單了解Python3 bytes和str類型的區(qū)別和聯(lián)系,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-12-12