Django笔记二十二之多数据库操作

本文首发于公众号:Hunter后端
原文链接:Django笔记二十二之多数据库操作

这一篇笔记介绍一下多数据库操作。

在第十篇笔记的时候,简单介绍过 using() 的使用方法,多个数据库就是通过 using(db_alias) 的方式来来指定选中的数据库,这里介绍一下同步库表结构时候的操作。

  1. 定义方式
  2. 同步命令
  3. 指定数据库操作

1、定义方式

在 settings.py 的 DATABASES 变量中可以定义多个数据库,如果是多个数据库,示例如下:

DATABASES = {
    'default': {
        'NAME': 'app_data',
        'ENGINE': 'django.db.backends.postgresql',
        'USER': 'postgres_user',
        'PASSWORD': 's3krit'
    },
    'users': {
        'NAME': 'user_data',
        'ENGINE': 'django.db.backends.mysql',
        'USER': 'mysql_user',
        'PASSWORD': 'superS3cret'
    },
    'customers': {
        'NAME': 'customer_data',
        'ENGINE': 'django.db.backends.mysql',
        'USER': 'mysql_cust',
        'PASSWORD': 'veryPriv@ate'
    }
}

通过 DATABASES 的 key 定义不同数据库的名称,使用的时候就可以根据这几个 key 来连接访问。

2、同步命令

之前介绍过 migrate 的相关命令,比如:

python3 manage.py migrate

之前的这种操作是因为系统都是使用的默认的数据库,也就是 default,如果是需要对其他数据库进行相关 migrate 的操作,需要通过 --database=db_alias 的命令来指定数据库。

比如需要对 users 数据库进行表结构的操作,命令如下:

python3 manage.py migrate --database=users

当然,如果我们使用的还是 default 数据库,那么加不加 --database 参数都可以。

3、指定数据库操作

对于数据库的操作,比如说获取 Blog 这个 model 的所有数据,如果是 default 数据库,那么命令则是:

Blog.objects.all()

而如果这个 model 是指定的其他数据库,比如 users,那么使用前需要通过 using(db_alias) 来指定:

db_alias = "users"
Blog.objects.using(db_alias).all()

以及一些其他的操作:

blog = Blog.objects.using(db_alias).get(id=1)

Blog.objects.using(db_alias).filter(id=1).delete()

# 下面的是新建的保存操作:
obj.save(using=db_alias)

以上就是本篇笔记的全部内容,下一篇将介绍如何使用 model 的条件表达式的搜索,更新等操作。

如果想获取更多后端相关文章,可扫码关注阅读:
image

原文链接:https://www.cnblogs.com/hunterxiong/p/17307862.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django笔记二十二之多数据库操作 - Python技术站

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

相关文章

  • python程序实现BTC(比特币)挖矿的完整代码

    实现比特币挖矿的完整代码是一项复杂的任务。以下是一些步骤,可帮助您开始编写这种代码,并向您展示一些示例。 1. 了解比特币挖矿的基础知识 在编写比特币挖矿代码之前,您需要了解比特币挖矿的基础知识。比特币是一种基于区块链技术的加密货币。它的设计目的是通过参与挖矿来保障比特币交易的安全性和稳定性。比特币挖矿需要高性能计算机来解决复杂的数学难题,以获得比特币。 2…

    python 2023年6月3日
    00
  • 如何在Python中删除MySQL数据库中的数据?

    以下是在Python中删除MySQL数据库中的数据的完整使用攻略。 使用MySQL数据库的前提条件 在使用Python连接MySQL数据库之前,确保已经装了MySQL数据库,并已经创建了使用的数据库和表。同时,还需要安装Python的动程序,例如mysql–python。 步骤1:导入模块 在Python中,使用mysql.connector模块连接MyS…

    python 2023年5月12日
    00
  • ptyhon实现sitemap生成示例

    下面就来详细讲解一下“Python实现Sitemap生成示例”的完整攻略。 1. Sitemap是什么 Sitemap即网站地图,是指展示网站结构的一种文件。它可以让搜索引擎更好地了解网站的页面结构,从而更快地收录网站内容。 2. Python实现Sitemap生成的基本步骤 Python实现Sitemap生成的基本步骤如下: 安装所需的依赖包:lxml、b…

    python 2023年6月3日
    00
  • python 爬虫一键爬取 淘宝天猫宝贝页面主图颜色图和详情图的教程

    Python爬虫一键爬取淘宝天猫宝贝页面主图颜色图和详情图的教程 本文将详细讲解如何使用Python爬虫一键爬取淘宝天猫宝贝页面的主图颜色图和详情图。我们将使用Python中的requests、BeautifulSoup和urllib库来实现这个功能。 1. 获取宝贝页面的HTML源代码 首先,我们需要获取宝贝页面的HTML源代码。可以使用requests库…

    python 2023年5月15日
    00
  • python爬虫中的url下载器用法详解

    Python爬虫中的URL下载器用法详解 在Python爬虫中,URL下载器是一个重要的组件,用于下载网页内容并保存到本地或内存中。以下是两个示例,介绍了如何使用Python实现URL下载器。 示例一:使用Python实现URL下载器 以下是一个示例,可以使用Python实现URL下载器: import requests def download(url):…

    python 2023年5月15日
    00
  • Python 文件数据读写的具体实现

    Python文件数据读写的具体实现 在Python中,文件数据读写是一项非常常见的任务。Python提供了许多内置函数和模块来写文件数据。本文将为您提供一个完整攻略,详细讲解Python文件数据读写的具体实现,包括文件打开读写、关闭和两个示例说明。 1. 文件打开 在Python中,可以使用open()函数打开一个文件。open()接受两个参数:文件名和打开…

    python 2023年5月14日
    00
  • python中time tzset()函数实例用法

    当我们使用 Python 进行时间计算时,时区始终是一个关键的问题。Python 的 time 模块提供了一个 tzset() 函数,用于设置当前系统的本地时区信息。本篇文章将详细讲解 Python 中 time tzset() 函数的用法。 函数参数 此函数不接受参数。 示例1 以下示例展示了如何在 Python 中使用 tzset() 函数设置本地时区信…

    python 2023年6月3日
    00
  • 在python中如何建立一个自己的包

    在Python中,我们可以把相关的功能函数或类封装成模块,以便在其他地方重复使用。而当我们有多个相关模块时,为了方便管理和使用,就可以将它们打包成一个完整的包(package)。 下面是建立一个自己的包的完整攻略。 1. 创建包目录 第一步是创建一个包目录。这个目录要满足以下要求: 目录名可以是任何合法的标识符,通常采用小写字母和下划线组成,比如my_pac…

    python 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部