django使用多个数据库实现

一、说明:

  在开发 Django 项目的时候,很多时候都是使用一个数据库,即 settings 中只有 default 数据库,但是有一些项目确实也需要使用多个数据库,这样的项目,在数据库配置和使用的时候,就比较麻烦一点。

二、Django使用多个数据库中settings中的DATABASES的设置

  2.1 默认只是用一个数据库时 DATABASES 的设置(以 SQLite 为例)

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',         
        'NAME': 'db.sqlite3',
    }
}

  2.2 Django 数据库支持的 ENGINE 类型

    • 'django.db.backends.postgresql'
    • 'django.db.backends.mysql'
    • 'django.db.backends.sqlite3'
    • 'django.db.backends.oracle'

  2.3 设置了多个数据库后 settings 中的 DATABASES 的设置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'db.sqlite3',
    },
    'db1': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mysql_test_db1',
        'USER': 'root',
        'PASSWORD': 'Se7eN521',
        'HOST': '127.0.0.1',
        'PORT': '3306'
    },
    'db2': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mysql_test_db2',
        'USER': 'root',
        'PASSWORD': 'Se7eN521',
        'HOST': '127.0.0.1',
        'PORT': '3306'
    }
}

三、实现思路

  1. 多个应用对应多个数据库和一个应用对应多个数据库
    1. 情况一:项目有多个 应用app 且需要使用到多个数据库
    2. 情况二:项目只有一个应用app, 且但需要使用到多个数据库,
  2. 这两种情况的实现思路其实都是一样的,都是为每个数据库创建一个应用,即这个应用只对接一个数据库,如果这个应用不需要写任何业务逻辑的代码,也需要创建一个空的应用,主要是用来做数据库迁移的
  3. 核心思想就是:一个model类对应一个数据库,通过数据库路由和model定义时指定的all_label来实现。

四、案例实现

  第一步:创建需要的 应用app,并且在 INSTALLED_APPS 中引用

    其中db1_app这个应用主要是用来对接数据库db1的

    其中db2_app这个应用主要是用来对接数据库db2的

    其中test_app这个应用主要用来实现业务逻辑的

                 django使用多个数据库实现

  第二步:创建 应用app 和 数据库之间的映射关系

    在settings.py 文件夹中设置 DATABASE_APPS_MAPPING 的字典,里面主要是配置 应用app 和数据库的对应关系

DATABASE_APPS_MAPPING = {
    "db1_app": "db1",   # db1_app 对应 db1 数据库
    "db2_app": "db2"    # db2_app 对应 db2 数据库
}

  第三步:创建数据库路由

    在项目的主文件夹即 settings.py 的同目录下创建一个 database_router.py 文件,该文件的作用就是给不同应用app 配置不同的数据库。

# _*_ coding:utf-8 _*_
# @Time : 2023/4/20 5:37 下午

from django.conf import settings

DATABASE_MAPPING = settings.DATABASE_APPS_MAPPING
print('DATABASE_MAPPING = {}'.format(DATABASE_MAPPING))

class DatabaseAppsRouter(object):

    # 设置 应用app 读取时数据库的设置
    def db_for_read(self, model, **hints)if model._meta.app_label in DATABASE_MAPPING:
            return DATABASE_MAPPING[model._meta.app_label]
        return None

    def db_for_write(self, model, **hints):
        if model._meta.app_label in DATABASE_MAPPING:
            return DATABASE_MAPPING[model._meta.app_label]
        return None

    def allow_relation(self, obj1, obj2, **hints):
        db_obj1 = DATABASE_MAPPING.get(obj1._meta.app_label)
        db_obj2 = DATABASE_MAPPING.get(obj2._meta.app_label)
        if db_obj1 and db_obj2:
            if db_obj1 == db_obj2:
                return True
            else:
                return False
        return None

    def allow_migrate(self, db, app_label, model_name=None, **hints):
        """
        Make sure that apps only appear in the related database.
        根据app_label的值只在相应的数据库中创建一个表,如果删除该def或
        不指定过滤条件,则一个Model会在每个数据库里都创建一个表。
        """
        if db in DATABASE_MAPPING.values():return DATABASE_MAPPING.get(app_label) == db
        elif app_label in DATABASE_MAPPING:
            return False
        return None

  第四步:在setting.py中配置 DATABASE_ROUTERS 指定自由路由文件:

#test_django为项目名,database_router为路由文件名,DatabaseAppsRouter为路由中创建的类名
DATABASE_ROUTERS = ['django_db_demo.database_router.DatabaseAppsRouter']

  第五步:创建model类

    说明:model 可以根据需要卸载任何一个应用app的model.py文件中,也可以分散写在多个应用的model.py中,这个根据自己的需要即可,但是如何推荐一定要在model类的Meta中指定app_label。不然会全部将表创建到default数据库中

from django.db import models

class SqliteModel(models.Model):
    """帐号和用户关联"""

    sqlite_name = models.CharField(max_length=20)
    class Meta:
        # 当前这个 SqliteModel 定义的数据库的表将会创建在test_app 对应的default 数据库中
        app_label = "test_app"      # 当有多个数据库链接的时候,要通过app_label 来区分这个model对应那个数据库
   
class Db1Model(models.Model):
    """帐号和用户关联"""

    db1_name = models.CharField(max_length=20)
    class Meta:
        # 当前这个Db1Model 定义的数据库的表将会创建在 db1_app 对应的 db1 数据库中
        app_label = "db1_app"        # 当有多个数据库链接的时候,要通过app_label 来区分这个model对应那个数据库
       
class Db2Model(models.Model):
    """帐号和用户关联"""

    db2_name = models.CharField(max_length=20)
    class Meta:
        # 当前这个Db2Model 定义的数据库的表将会创建在 db2_app 对应的 db1 数据库中
        app_label = "db2_app"       # 当有多个数据库链接的时候,要通过app_label 来区分这个model对应那个数据库
      

  

  第六步:数据迁移

python3 manage.py makemigrations  
python3 manage.py migrate --database=default   # 当有多个数据库,需要迁移多次
python3 manage.py migrate --database=db1
python3 manage.py migrate --database=db2 

  第七步:查看迁移:

    model对应的表,分别迁移到不同的数据库成功,剩下的增删改查的就正常引入model对象即可,这样就实现了,不同的model对象,对应不用数据库的表。

    django使用多个数据库实现

第五步:总结

  1. 创建多个数据库连接设置
  2. 创建多个数据与应用app的映射关系
  3. 创建数据库路由
  4. 创建model类的时候置指明app_label,即这个model是属于那个app,从而觉得迁移到那个数据库

原文链接:https://www.cnblogs.com/Se7eN-HOU/p/17339885.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:django使用多个数据库实现 - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • Python3.8 + Tkinter: Button设置image属性不显示的问题及解决方法

    接下来我将详细讲解“Python3.8 + Tkinter: Button设置image属性不显示的问题及解决方法”的完整攻略。 问题描述 在Python3.8 + Tkinter下,按钮(Button)组件设置image属性时,有时会出现图片不显示的情况。这可能会导致用户无法正确识别按钮的功能,影响用户体验。 原因分析 这种情况发生的原因在于,Python…

    python 2023年6月13日
    00
  • 使用 Python 请求模块处理两步身份验证

    【问题标题】:Handling two step authentication using Python requests module使用 Python 请求模块处理两步身份验证 【发布时间】:2023-04-02 07:05:02 【问题描述】: 我的要求是从身份验证服务器捕获 cookie,我可以使用请求模块来实现它。但是,当启用“两步验证”时,这段代…

    Python开发 2023年4月8日
    00
  • Python 异步之如何获取当前和正在运行任务详解

    Python 异步之获取当前和正在运行任务详解 在 Python 异步编程中,我们经常需要获取当前的任务以及正在运行的任务。本文将介绍如何使用 asyncio 模块和相关方法来获取这些信息。 获取当前任务 要获取当前的任务,我们可以使用 asyncio.current_task() 方法。该方法返回当前协程对象的 Task 实例。在异步中,Task 是 as…

    python 2023年5月14日
    00
  • Python判断变量是否为Json格式的字符串示例

    这里是Python判断变量是否为Json格式的字符串示例的完整攻略。 什么是JSON格式字符串 JSON是一种数据交换格式,通常用于前后端的数据传输。JSON文本由键值对组成,并使用花括号{}表示对象,使用中括号[]表示数组。下面是一个JSON格式的字符串示例: { "name": "Jack", "age&…

    python 2023年6月3日
    00
  • python实现统计汉字/英文单词数的正则表达式

    以下是“Python实现统计汉字/英文单词数的正则表达式”的完整攻略: 一、问题描述 在Python中,我们可以使用正则表达式来统计汉字和英文单词的数量。本文将详细讲解Python实现统计汉字/英文单词数的正则表达式的方法,以及如何在实际开发中应用。 二、解决方案 2.1 统计汉字的数量 在Python中,统计汉字的数量可以使用正则表达式来实现。我们可以使用…

    python 2023年5月14日
    00
  • Python应用库大全总结

    Python应用库大全总结 Python是一种功能强大的编程语言,拥有丰富的应用库,可以帮助我们快速开发各种应用程序。本攻略将介绍一些常用的Python应用库,以及它们的用途和示例。 NumPy NumPy是Python中用于科学计算的基础库之一。它提供了高性能的多维数组对象,以及用于处理这些数组的工具。NumPy可以用于数学、科学、工程和数据分析等领域。 …

    python 2023年5月15日
    00
  • Python实现的生成自我描述脚本分享(很有意思的程序)

    首先,这篇文章是介绍如何生成一个自我描述的Python脚本,这个脚本可以使用Python自身的函数来生成它所需要的代码,使得这个脚本与Python的语言特性高度匹配。 生成自我描述脚本的过程可以分为以下几步:1. 定义需要生成的代码结构;2. 构造函数,生成需要的代码段;3. 使用代码段构造完整的自我描述脚本。 下面,我们来逐步实现这个过程: 1. 定义需要…

    python 2023年6月3日
    00
  • 详解Python按属性对自定义对象的元组进行排序

    当我们有一个自定义对象的元组列表时,如果要按照元组中的某个属性进行排序,可以使用Python中的sorted函数以及lambda表达式来实现。 以下是按属性对自定义对象的元组进行排序的完整攻略。 创建自定义对象 首先,我们要创建一个自定义对象,该对象包含多个属性。例如,我们创建一个Person类,该类有name、age和country属性。 class Pe…

    python-answer 2023年3月25日
    00
合作推广
合作推广
分享本页
返回顶部