<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
一個APP對應一個預設資料庫,若連線其他資料庫用".using()"
Author.objects.using('db02').all()
1、在專案settings中增加資料庫設定
# settings.py DATABASES = { 'default': { 'ENGINE': 'django.db.backends.oracle', 'NAME': 'orcl19c', 'USER': "username01", 'PASSWORD': "password01", 'HOST': "110.10.1.11", 'PORT': 1511, }, 'db_2': { 'ENGINE': 'django.db.backends.oracle', 'NAME': 'orcl19c', 'USER': "username02", 'PASSWORD': "password02", 'HOST': "120.20.2.22", 'PORT': 1512, } } # 以下MyProject改成專案名,預設default不用修改 DATABASE_ROUTERS = ['MyProject.database_router.DatabaseAppsRouter'] DATABASE_APPS_MAPPING = { 'app01': 'default', 'app02': 'db_2', }
2、在專案根目錄下Myproject/Myproject 新建資料庫路由檔案database_router.py
直接複製以下程式碼,無需修改
from django.conf import settings DATABASE_MAPPING = settings.DATABASE_APPS_MAPPING class DatabaseAppsRouter(object): """ A router to control all database operations on models for different databases. In case an app is not set in settings.DATABASE_APPS_MAPPING, the router will fallback to the `default` database. Settings example: DATABASE_APPS_MAPPING = {'app1': 'db1', 'app2': 'db2'} """ def db_for_read(self, model, **hints): """"Point all read operations to the specific database.""" if model._meta.app_label in DATABASE_MAPPING: return DATABASE_MAPPING[model._meta.app_label] return None def db_for_write(self, model, **hints): """Point all write operations to the specific database.""" if model._meta.app_label in DATABASE_MAPPING: return DATABASE_MAPPING[model._meta.app_label] return None def allow_relation(self, obj1, obj2, **hints): """Allow any relation between apps that use the same database.""" 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_syncdb(self, db, model): """Make sure that apps only appear in the related database.""" if db in DATABASE_MAPPING.values(): return DATABASE_MAPPING.get(model._meta.app_label) == db elif model._meta.app_label in DATABASE_MAPPING: return False return None def allow_migrate(self, db, app_label, model=None, **hints): """ Make sure the auth app only appears in the 'auth_db' database. """ if db in DATABASE_MAPPING.values(): return DATABASE_MAPPING.get(app_label) == db elif app_label in DATABASE_MAPPING: return False return None
3、使用inspectdb反向生成各app的model類之後,設定model類對應要連結的資料庫
反向生成models.py 命令:
python manage.py inspectdb --database db1 TableName1 > app01/models.py python manage.py inspectdb --database db2 TableName2 > app02/models.py
# 編輯app01下的models.py: class Names(models.Model): #該model使用default資料庫 id=models.CharField(primary_key=True,max_length=100, blank=True, null=True) name=models.CharField(max_length=32,primary_key=True,unique=True) class Meta: #app_label = 'app01' #由於該model連線default資料庫,所以在此無需指定 db_table = 'names' # 編輯app02下的models.py: class Classnum(models.Model): #該model使用default資料庫 id=models.CharField(primary_key=True,max_length=100, blank=True, null=True) classnum=models.CharField(max_length=32,primary_key=True,unique=True) class Meta: app_label = 'app02' db_table = 'classnum'
4、同步資料庫
# 同步default節點資料庫,只執行不帶 --database引數的命令,不對其他資料庫進行同步 python manage.py makemigrations python manage.py migrate # 同步db02節點資料庫: python manage.py makemigrations python manage.py migrate --database=db02
5、若要連線設定外的資料庫
Author.objects.using('other').all() my_object.save(using='legacy_users') my_object.delete(using='legacy_users')
移動物件到另一個資料庫時會發生主鍵衝突,可以使用obj.pk方法清除主鍵再儲存物件
>>> p = Person(name='Fred') >>> p.save(using='first') >>> p.pk = None # Clear the primary key. >>> p.save(using='second') # Write a
總結
到此這篇關於Django專案設定連線多個資料庫的文章就介紹到這了,更多相關Django設定連線多資料庫內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45