簡單了解Django ContentType內置組件
一、引出問題
假如有這兩張表,它們中的課程可能價格不一樣、周期不一樣、等等...不一樣...,現(xiàn)在有一張價格策略表,怎么就用一張表報保存它們之間不同的數(shù)據(jù)呢?
可能你會這樣:
確實是行!但是,如果有很多不同類型的課程,那么這樣表就太多空值了!
沒辦法,這一張表不行,再創(chuàng)建一張不就行了,就像這樣:
確實,對于這種情況,Django就是這樣做的。
現(xiàn)在,有了 ContentType,我們只需創(chuàng)建三張表,就實現(xiàn)跟上面的效果一模一樣了。
這是因為 Django 本身就會新建 django_content_type 這張表,這張表就保存了 model 中的表名。
二、ContentType
那么怎么創(chuàng)建這種關系呢?如下:
這里,DegreeCourse 表沒有使用 GenericRelation,則不能使用下面說的第3點,否則報錯,要想使用就跟 Course 表一樣添加即可。
對于 GenericRelation 和 GenericForeignKey 類型字段,不會在數(shù)據(jù)庫生成列!
三、測試
# views.py from django.shortcuts import HttpResponse from django.contrib.contenttypes.models import ContentType from appxx import models
1、在價格策略表中添加一條數(shù)據(jù)。
# 方式1 def test(request): models.PricePolicy.objects.create( price=100, valid_period=7, object_id=3, content_type=ContentType.objects.get(model="course") ) return HttpResponse("ok")
# 方式2 def test(request): models.PricePolicy.objects.create( price=200, valid_period=14, content_object=models.Course.objects.get(id=3) # 對應Course表id為3的價格策略 # content_object=models.DegreeCourse.objects.get(id=2) # 對應DegreeCourse表id為2的價格策略 ) return HttpResponse("ok")
2、 根據(jù)某個價格策略對象,找到對應的表和數(shù)據(jù)。(是根據(jù) GenericForeignKey類型字段實現(xiàn)的)
def test(request): obj = models.PricePolicy.objects.get(id=1) print(obj.content_object.id, obj.content_object.name) # 自動找到 return HttpResponse("ok")
3、 找到某個課程關聯(lián)的所有價格策略。(是根據(jù) GenericRelation 類型字段實現(xiàn)的)
def test(request): obj = models.Course.objects.get(id=1) for item in obj.policy_list.all(): print(item.id, item.price, item.valid_period) return HttpResponse("ok")
關系圖:
四、總結
什么時候才用ContentType?
當一張表跟 n 張表動態(tài)地創(chuàng)建 ForeignKey 關系時,而不是創(chuàng)建太多列,因為數(shù)據(jù)表中會有很多空值。
ContentType 通過僅兩列字段就實現(xiàn)了 n 張表的 ForeignKey 關系。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
一文帶你掌握Pyecharts地理數(shù)據(jù)可視化的方法
這篇文章主要介紹了一文帶你掌握Pyecharts地理數(shù)據(jù)可視化的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Python的Flask框架中實現(xiàn)登錄用戶的個人資料和頭像的教程
這篇文章主要介紹了Python的Flask框架中實現(xiàn)登錄用戶的個人資料和頭像的教程,這也是各個web框架的最基本功能之一,需要的朋友可以參考下2015-04-04python如何使用pywebview打造一個現(xiàn)代化的可視化GUI界面詳解
pywebview是一個輕量級的跨平臺庫,它可以讓你在Python程序中嵌入一個瀏覽器窗口,下面這篇文章主要給大家介紹了關于python如何使用pywebview打造一個現(xiàn)代化的可視化GUI界面的相關資料,需要的朋友可以參考下2024-07-07python2 與python3的print區(qū)別小結
這篇文章主要介紹了python2 與python3的print區(qū)別小結,需要的朋友可以參考下2018-01-01Python利用arcpy模塊實現(xiàn)柵格的創(chuàng)建與拼接
這篇文章主要為大家詳細介紹了如何基于Python語言arcpy模塊,實現(xiàn)柵格影像圖層建立與多幅遙感影像數(shù)據(jù)批量拼接(Mosaic)的操作,感興趣的可以了解一下2023-02-02python?selenium.webdriver?爬取政策文件的實現(xiàn)
本文主要介紹了python?selenium.webdriver?爬取政策文件的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07