Django筆記二十二之多資料庫操作

XHunter發表於2023-04-11

本文首發於公眾號: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

相關文章