Django組件content-type使用方法詳解

前言

一個表和多個表進行關聯,但具體隨着業務的加深,表不斷的增加,關聯的數量不斷的增加,怎麼通過一開始通過表的設計後,不在後期在修改表,徹底的解決這個問題呢呢

django中的一個組件content-type可以幫助我們解決這樣的一個問題

在這裏我先設計了3張表 學位表 普通課程 和價格策略表 大致的設計如下

 

 

 在上圖中我們可以看到價格策略表和其他的兩個表進行了關聯,可以根據表明

from django.db import models
from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
from django.contrib.contenttypes.models import ContentType
 
 
class Course(models.Model):
  """
  普通課程
  """
  title = models.CharField(max_length=32)
  # 僅用於反向查找 不在數據庫中添加字段
  price_policy_list = GenericRelation("PricePolicy")
 
class DegreeCourse(models.Model):
  """
  學位課程
  """
  title = models.CharField(max_length=32)
 
  # 僅用於反向查找
  price_policy_list = GenericRelation("PricePolicy")
 
 
class PricePolicy(models.Model):
  """
  價格策略
  """
  price = models.IntegerField()
  period = models.IntegerField()
 
  # 關聯表
  content_type = models.ForeignKey(ContentType, verbose_name='關聯的表名稱') # 7,8 表名稱
  object_id = models.IntegerField(verbose_name='關聯的表中的數據行的ID')  #
  # 幫助你快速實現content_type操作 ,快速插入數據 不生成數據庫中的字段
  content_object = GenericForeignKey('content_type', 'object_id')
進行插入數據的類視圖
from django.shortcuts import render,HttpResponse
from app01 import models
def test(request):
 
  # 1. 爲學位課“Python全棧”添加一個價格策略:一個月 9.9
  # obj1 = models.DegreeCourse.objects.filter(title='Python全棧').first()
  # models.PricePolicy.objects.create(price=9.9, period=30, content_object=obj1)
  #
  # obj2 = models.DegreeCourse.objects.filter(title='Python全棧').first()
  # models.PricePolicy.objects.create(price=19.9, period=60, content_object=obj2)
  #
  # obj3 = models.DegreeCourse.objects.filter(title='Python全棧').first()
  # models.PricePolicy.objects.create(price=29.9, period=90, content_object=obj3)
 
  # 2. 爲學位課“rest”添加一個價格策略:一個月 9.9
  # obj1 = models.Course.objects.filter(title='rest framework').first()
  # models.PricePolicy.objects.create(price=9.9, period=30, content_object=obj1)
  #
  # obj2 = models.Course.objects.filter(title='rest framework').first()
  # models.PricePolicy.objects.create(price=19.9, period=60, content_object=obj2)
  #
  # obj3 = models.Course.objects.filter(title='rest framework').first()
  # models.PricePolicy.objects.create(price=29.9, period=90, content_object=obj3)
 
  # 3. 根據課程ID獲取課程, 並獲取該課程的所有價格策略
  # course = models.Course.objects.filter(id=1).first()
  #
  # price_policys = course.price_policy_list.all()
  #
  # print(price_policys)
 
 
  return HttpResponse('...')
爲其添加路由
from django.conf.urls import url
from django.contrib import admin
from app01 import views
 
urlpatterns = [
  url(r'^admin/', admin.site.urls),
  url(r'^test/', views.test),
]
我們自己進行插入數據可能會這樣寫
# 1. 爲學位課“Python全棧”添加一個價格策略:一個月 9.9
"""
obj = DegreeCourse.objects.filter(title='Python全棧').first()
# obj.id
cobj = ContentType.objects.filter(model='course').first()
# cobj.id
PricePolicy.objects.create(price='9.9',period='30',content_type_id=cobj.id,object_id=obj.id)
"""
# obj = DegreeCourse.objects.filter(title='Python全棧').first()
# PricePolicy.objects.create(price='9.9',period='30',content_object=obj)

  

 
 
 
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章