qhfl-2 ContentType组件
一般商城里有很多的商品,计优惠券对应着活动类型商品,家电是一类商品,食物是一类商品,优惠券对应着不同的商品类别。 from django.db import models class Appliance(models.Model):
"""
家用电器表
id name
冰箱
电视
洗衣机
"""
name = models.CharField(max_length=64) class Food(models.Model):
"""
食物表
id name
面包
牛奶
"""
name = models.CharField(max_length=32) class Fruit(models.Model):
"""
水果表
id name
苹果
香蕉
"""
name = models.CharField(max_length=32) class Coupon(models.Model):
"""
优惠券表
id name appliance_id food_id fruit_id
通用优惠券 null null null
冰箱折扣券 1 null null
电视折扣券 2 null null
苹果满减卷 null null 1
我每增加一张表就要多增加一个字段
"""
name = models.CharField(max_length=32)
appliance = models.ForeignKey(to="Appliance", null=True, blank=True)
food = models.ForeignKey(to="Food", null=True, blank=True)
fruit = models.ForeignKey(to="Fruit", null=True, blank=True)<br># 实际上我们商品的种类会特别的多,导致我们这张表外键越来越多
遇到这种一张表要跟多张表进行外键关联的时候~我们Django提供了ContentType组件~ 需求
需求
ContentType组件
ContentType是Django的内置的一个应用,可以追踪项目中所有的APP和model的对应关系,并记录在ContentType表中。
当我们的项目做数据迁移后,会有很多django自带的表,其中就有django_content_type表
ContentType组件应用:
-- 在model中定义ForeignKey字段,并关联到ContentType表,通常这个字段命名为content-type
-- 在model中定义PositiveIntergerField字段, 用来存储关联表中的主键,通常我们用object_id
-- 在model中定义GenericForeignKey字段,传入上面两个字段的名字
-- 方便反向查询可以定义GenericRelation字段
基于ContentType创建表结构
from django.db import models
from django.contrib.contenttypes.models import ContentType
from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation # Create your models here. class Food(models.Model):
"""
id title
1 面包
2 牛奶
"""
title = models.CharField(max_length=32)
# 不会生成字段 只用于反向查询
coupons = GenericRelation(to="Coupon") class Fruit(models.Model):
"""
id title
1 苹果
2 香蕉
"""
title = models.CharField(max_length=32) # 如果有40张表
# class Coupon(models.Model):
# """
# id title food_id fruit_id
# 1 面包九五折 1 null
# 2 香蕉满10元减5元 null 2
# """
# title = models.CharField(max_length=32)
# food = models.ForeignKey(to="Food")
# fruit = models.ForeignKey(to="Fruit") # class Coupon(models.Model):
# """
# id title table_id object_id
# 1 面包九五折 1 1
# 2 香蕉满10元减5元 2 2
# """
# title = models.CharField(max_length=32)
# table = models.ForeignKey(to="Table")
# object_id = models.IntegerField()
#
#
# class Table(models.Model):
# """
# id app_name table_name
# 1 demo food
# 2 demo fruit
# """
# app_name = models.CharField(max_length=32)
# table_name = models.CharField(max_length=32)
view
class Coupon(models.Model):
title = models.CharField(max_length=32) # 优惠券的名称
# 第一步
content_type = models.ForeignKey(to=ContentType, on_delete=None) # 商品表
# 第二步
object_id = models.IntegerField() # 商品对象的id
# 第三步 不会生成字段
content_object = GenericForeignKey("content_type", "object_id")
# # 绑定外键关系,防止商品id不在商品表里面
这样无论有多少张优惠券,都只需要外键关联Content_type一张表(里面存着所有表的关系),然后指明对象的id,就能找到优惠券对应的商品
当一张表跟多张表有外键关系时,都可以通过 ContentType 组件来建立
ContentType 查询
demo/views.py
from rest_framework.views import APIView
from rest_framework.response import Response
from .models import Food, Coupon
from django.contrib.contenttypes.models import ContentType class DemoView(APIView): def get(self, request): # 给面包创建一个优惠券
food_obj = Food.objects.filter(id=1).first()
# Coupon.objects.create(title="面包九五折", content_type_id=8, object_id=1) # 比较麻烦,需要找表id
# Coupon.objects.create(title="双十一面包九折促销", content_object=food_obj) # 查询面包都有哪些优惠券
coupons = food_obj.coupons.all()
print(coupons)
# 优惠券查对象
coupon_obj = Coupon.objects.filter(id=1).first()
content_obj = coupon_obj.content_object
print(coupon_obj.title) """
<QuerySet [<Coupon: Coupon object (1)>, <Coupon: Coupon object (2)>, <Coupon: Coupon object (3)>, <Coupon: Coupon object (4)>]>
面包九五折
""" # 通过ContentType表找表模型
content = ContentType.objects.filter(app_label="demo", model="food").first()
print(content)
model_class = content.model_class()
ret = model_class.objects.all()
print(ret)
"""food
<QuerySet [<Food: Food object (1)>, <Food: Food object (2)>]>
return Response("ContentType测试")
"""

qhfl-2 ContentType组件的更多相关文章
- content-type 组件
content-type初识 什么是content-type ContentType是Django的内置的一个应用,可以追踪项目中所有的APP和model的对应关系,并记录在ContentType表中 ...
- Django之ContentType组件
一.理想表结构设计 1.初始构建 1. 场景刚过去的双12,很多电商平台都会对他们的商品进行打折促销活动的,那么我们如果要实现这样的一个场景,改如何设计我们的表? 2. 初始表设计 注释很重要,看看吧 ...
- python全栈开发day103-python垃圾回收机制、mro和c3算法解析、跨域jsonp\CORS、Content-Type组件
Python垃圾回收 -- 引用计数 -- Python为每个对象维护一个引用计数 -- 当引用计数为0的 代表这个对象为垃圾 -- 标记清除 -- 解决孤立的循环引用 -- 标记根节点和可达对象 - ...
- Django ContentType组件
ContentType组件 引入 现在我们有这样一个需求~我们的商城里有很多的商品~~节日要来了~我们要搞活动~~ 那么我们就要设计优惠券~~优惠券都有什么类型呢~~满减的~折扣的~立减的~~ 我们对 ...
- python 全栈开发,Day98(路飞学城背景,django ContentType组件,表结构讲解)
昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...
- Django组件(五) Django之ContentType组件
基础使用 -contenttype组件 -django提供的一个快速连表操作的组件,可以追踪项目中所有的APP和model的对应关系,并记录在ContentType表中. 当我们的项目做数据迁移后,会 ...
- ContentType组件,Django缓存机制,跨域请求
ContentType组件 解决什么问题:表的id和数据id,来唯一确定一条数据 用: 插入数据: models:content_obj = GenericForeignKey('table_id', ...
- contenttype组件、Django缓存机制以及跨域请求
1 昨日回顾 版本控制 *** (1)url=127.0.0.1/course/?version=v100000 1 versioning_class=QueryParameterVersioning ...
- Django-缓存机制、跨域请求(CORS)、ContentType组件
Django缓存机制: 在settings中间件里面设置: 三个粒度: 1 全站缓存 用中间件: MIDDLEWARE = [ # 'django.middleware.cache.UpdateCac ...
随机推荐
- Oracle 学习笔记(二)
一.索引 表的数据是无序的,所以叫堆表(heap table),意思为随机存储数据.因为数据是随机存储的,所以在查询的时候需要全表扫描.索引就是将无序的数据有序化,这样就可以在查询数据的时候 减少数据 ...
- nodejs server websocket
var WebSocketServer = require('websocket').server; var http = require('http'); var server = http.cre ...
- 一致性hash算法及java实现
一致性hash算法是分布式中一个常用且好用的分片算法.或者数据库分库分表算法.现在的互联网服务架构中,为避免单点故障.提升处理效率.横向扩展等原因,分布式系统已经成为了居家旅行必备的部署模式,所以也产 ...
- javac编译错误: 编码UTF8/GBK的不可映射字符
转自:https://blog.csdn.net/leytton/article/details/52740171 Linux下为UTF-8编码,javac编译gbk编码的java文件时,容易出现“错 ...
- 《从零玩转python+人工智能-3》120,122节课深度优先疑问解答
深度优先(从左往右): 按照这个原则来:至于使用栈,或者队列:根据它们不同的特性:最终务必保证最终结果是原继承结构的“从左往右”:所以,如果是栈,就是右侧先入栈,左侧再入(这样左侧能先出来,遵循从左 ...
- iphone 开发h5 踩过的坑
html,body{ -webkit-text-size-adjust: none; } // 当需要在中文版chrome浏览器中显示小于12px的字体时,而且此时页面放大效果会被阻止 html,b ...
- python 列表 list的基本操作
一,Python 的列表数据类型包含更多的方法. 这里是所有的列表对象方法: list.append(x) 把一个元素添加到链表的结尾,相当于 a[len(a):] = [x] . list.exte ...
- python中安装request模块
使用命令行(cmd)进入到python安装目录下的Scripts文件夹(也可以先进入目标文件夹然后在文件路径上打开cmd回车即可) 在命令行中输入pip install requests,等待安装完成 ...
- php 计算 距离
function getdistance($lng1,$lat1,$lng2,$lat2){ //将角度转为狐度 $radLat1=deg2rad($lat1);//deg2rad()函数将角度转换为 ...
- springcloud-知识点总结(三):Hystrix & Dashboard & turbine & Zuul & SpringCloud Config
1.Hystrix断路器简介 Hystrix断路器简介 hystrix对应的中文名字是“豪猪”,豪猪周身长满了刺,能保护自己不受天敌的伤害,代表了一种防御机制,这与hystrix本身的功能不谋而合,因 ...