关于python:Django笔记二十二之多数据库操作

55次阅读

共计 1261 个字符,预计需要花费 4 分钟才能阅读完成。

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

在第十篇笔记的时候,简略介绍过 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 的条件表达式的搜寻,更新等操作。

本文首发于自己微信公众号:Django 笔记。

原文链接:Django 笔记二十二之多数据库操作

如果想获取更多相干文章,可扫码关注浏览:

正文完
 0