Django app配置多個(gè)數(shù)據(jù)庫(kù)代碼實(shí)例
這篇文章主要介紹了Django app配置多個(gè)數(shù)據(jù)庫(kù)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
每個(gè)app使用不同的數(shù)據(jù)庫(kù)
1. 配置數(shù)據(jù)庫(kù)連接
# 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ù)庫(kù)路由
# settings.py DATABASES_APPS_MAPPING = { 'app1': 'default', 'app2': 'db1', } DATABASE_ROUTERS = ['utils.database_router.DatabaseAppsRouter']
3. 數(shù)據(jù)庫(kù)路由文件:
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會(huì)訪問default數(shù)據(jù)庫(kù),使用app2的model會(huì)訪問db1數(shù)據(jù)庫(kù)
同一個(gè)app下使用不同數(shù)據(jù)庫(kù)
只需要在model class中修改app_label的值即可,app_label默認(rèn)為此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'
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解多線程Django程序耗盡數(shù)據(jù)庫(kù)連接的問題
- Django使用多數(shù)據(jù)庫(kù)的方法
- Django中數(shù)據(jù)庫(kù)的數(shù)據(jù)關(guān)系:一對(duì)一,一對(duì)多,多對(duì)多
- django 多數(shù)據(jù)庫(kù)配置教程
- Django多數(shù)據(jù)庫(kù)配置及逆向生成model教程
- django 多數(shù)據(jù)庫(kù)及分庫(kù)實(shí)現(xiàn)方式
- django 鏈接多個(gè)數(shù)據(jù)庫(kù) 并使用原生sql實(shí)現(xiàn)
- Django多數(shù)據(jù)庫(kù)的實(shí)現(xiàn)過程詳解
- Django多數(shù)據(jù)庫(kù)聯(lián)用實(shí)現(xiàn)方法解析
- django使用多個(gè)數(shù)據(jù)庫(kù)的方法實(shí)例
相關(guān)文章
python+Splinter實(shí)現(xiàn)12306搶票功能
這篇文章主要為大家詳細(xì)介紹了python+Splinter實(shí)現(xiàn)12306搶票功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-09-09Python實(shí)現(xiàn)刪除文件中含“指定內(nèi)容”的行示例
這篇文章主要介紹了Python實(shí)現(xiàn)刪除文件中含“指定內(nèi)容”的行功能,涉及Python針對(duì)文件讀取及字符串遍歷、判斷等相關(guān)操作技巧,需要的朋友可以參考下2017-06-06html網(wǎng)頁調(diào)用后端python代碼的方法實(shí)例
html頁面中確實(shí)能夠調(diào)用python程序,不過只能調(diào)“一點(diǎn)點(diǎn)”,下面這篇文章主要給大家介紹了關(guān)于html網(wǎng)頁調(diào)用后端python代碼的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01python工具——Mimesis的簡(jiǎn)單使用教程
這篇文章主要介紹了python工具——Mimesis的簡(jiǎn)單使用教程,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01導(dǎo)致python中import錯(cuò)誤的原因是什么
在本篇文章里小編給大家整理了關(guān)于python的import錯(cuò)誤原因以及相關(guān)內(nèi)容,需要的朋友們可以學(xué)習(xí)下。2020-07-07簡(jiǎn)單了解Python3 bytes和str類型的區(qū)別和聯(lián)系
這篇文章主要介紹了簡(jiǎn)單了解Python3 bytes和str類型的區(qū)別和聯(lián)系,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12