django 之 ContentType的使用
1. ContentType 是干什么用的呢:
1. ContentType: 主要的作用就是Django orm的创建表的时候,可以方便多表查询使用,简化多表查询的过程 2.ContentType 最主要的是有一个表内有多个字段映射不同的表的时候可以使用了
#最主要的其实就是一个数据表会经常变化,这样的话使用ContentType 组件,这样方便后期的修改和处理
2. ContentType的案例简单分析:
from django.db import models # Create your models here. from django.contrib.contenttypes.models import ContentType
from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
###加载ContentType 需要的模块组件 class Course(models.Model): #创建一个course 课程的表,免费的
id=models.AutoField(primary_key=True)
name=models.CharField(max_length=32) #它自己的字段 # 不会在数据库中生成字段,只用于数据库操作
policy = GenericRelation(to='PricePolicy') class DegreeCourse(models.Model): #创建一个收费的课程表
id=models.AutoField(primary_key=True)
name=models.CharField(max_length=32)
# 它自己的字段
policy = GenericRelation(to='PricePolicy') class PricePolicy(models.Model): #对应2个课程表的价格和学习的周期时间
id=models.AutoField(primary_key=True)
period=models.IntegerField()
price=models.DecimalField(max_digits=8,decimal_places=2) object_id=models.IntegerField() #这个就是精髓 这里的变量取值为object_id #不要加引号,因为文件里已经加载好了,不需要to=ContentType 加引号
content_type=models.ForeignKey(to=ContentType,null=True) #这个就是精髓 这里的变量取值为content_type # 引入一个字段,不会在数据库中创建,只用来做数据库操作
# content_obj = GenericForeignKey('content_type','object_id')
content_obj = GenericForeignKey() #以为上面2个变量赋值很巧妙, 所以这里GenericForeignKey()内不需要写内容了
使用一(给课程添加价格策略): 使用方法:
-给免费课django添加价格策略
course = models.Course.objects.get(pk=1)
ret = models.PricePolicy.objects.create(period=30, price=199.9, content_obj=course)
-给学位课程(python全栈开发)添加价格策略
degree_course = models.DegreeCourse.objects.get(pk=1)
ret = models.PricePolicy.objects.create(period=30, price=199.9, content_obj=degree_course)
使用一: 给课程添加价格策略
使用二:查询价格策略对应的课程:
price_policy = models.PricePolicy.objects.get(pk=1)
print(price_policy.content_obj)
使用三:通过课程获取价格策略
course = models.Course.objects.get(pk=1)
policy_list = couse.policy.all()
用contentType实现查询
# 查询所有价格策略,并且显示对应的课程名称
price_policy_list=models.PricePolicy.objects.all() #获取价格表的对象组
for price_policy in price_policy_list: #for 循环从列表组取出一个一个对象 print(price_policy.content_obj.name) #直接content_obj 可以多个表查询到想要的结果 # 查询django课程信息的所有价格策略
course=models.Course.objects.get(pk=1)
#policy_list 就是django这门课所有的价格策略对象
policy_list=course.policy.all()
for policy in policy_list:
print(policy.price) #查询python全栈开发的所有价格策略
degree_course=models.DegreeCourse.objects.get(pk=1)
policy_list=degree_course.policy.all()
for policy in policy_list:
print(policy.price)
使用contentType简单实现查询想要东西的代码
django 之 ContentType的使用的更多相关文章
- Django之ContentType组件
一.理想表结构设计 1.初始构建 1. 场景刚过去的双12,很多电商平台都会对他们的商品进行打折促销活动的,那么我们如果要实现这样的一个场景,改如何设计我们的表? 2. 初始表设计 注释很重要,看看吧 ...
- python框架之Django(15)-contenttype模块
假如有一个书城系统,需要给作者和书籍加上评论功能.如果给每个表单独建一个评论表,那么我们以后要扩展其它模块评论功能的时候,还需要随之新建一张评论表,会显得很冗余.对于这种情况,Django 给我们提供 ...
- Django组件(五) Django之ContentType组件
基础使用 -contenttype组件 -django提供的一个快速连表操作的组件,可以追踪项目中所有的APP和model的对应关系,并记录在ContentType表中. 当我们的项目做数据迁移后,会 ...
- Django之ContentType详解
contenttypes 是Django内置的一个应用,可以追踪项目中所有app和model的对应关系,并记录在ContentType表中. models.py文件的表结构写好后,通过makemigr ...
- Django的ContentType框架django_conent_type
Django包含了一个conenttype应用程序,记录了Django项目中安装的所有模型,为当前项目所有基于Django驱动的model提供了更高层次的抽象接口. 一.概述 ContentTypes ...
- Django中contenttype的应用
content_type表将app名称与其中的表的关系进行保存 通过下边的示例来理解content_type的具体应用: models: from django.db import models fr ...
- django之contenttype
平时开发过程中,我们会经常遇到这么一个类似的场景,比如 不同的课程,有不同的价格策略 不同的课程可使用不同的优惠券(满减券,通用券,专用券) 不同的评论区,支持的评论 就拿 不同的课程,有不同的价格 ...
- Django day31 contentType组件,Django的缓存
一.contentType组件 1.干什么用的? 是一个django内置的一个组件,方便我们快速的连表操作 2.这两个字段都不会在数据库中生成,他只是用来查询,插入的 -在course表中: poli ...
- 【Django】ContentType组件
目录 理解 表结构 使用 @ 好,现在我们有这样一个需求,我们的商城里有很多的商品,然而节日要来了,我们要搞活动. 那么,我们就要设计优惠券,优惠券都有什么类型呢?满减的.折扣的.立减的.等等等... ...
随机推荐
- C++跨平台集成websocketpp
之前给公司写了一个用于消息交互的服务器,移植到Linux上之后发现H5-Websocket模块经常出问题,而该模块是另一位已经离职同事编写的,所以修改和维护都存在一定的困难,索性就直接把这个模块替换掉 ...
- 第六节《Git克隆》
本节学习如何使用git clone命令建立版本库克隆,以及如何使用git push和gitpull命令实现克隆之间的同步. Git的版本库目录和工作区在一起,因此存在一损俱损的问题,即如果删除一个项目 ...
- python面试题--数据类型
数据类型 字典 dict:字典,字典是一组键(key)和值(value)的组合,通过键(key)进行查找,没有顺序, 使用大括号”{}”;应用场景:dict,使用键和值进行关联的数据; 现有字典d={ ...
- sql调优2
今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情.当我们去设计数据库表结构,对操作数据 ...
- linux 中 && 及|| 判断原理
[root@linuxprobe ~]# [ $USER = root ] && echo "root" || echo "user"root[ ...
- MySQL死锁分析一例
Tomcat日志报死锁错误,show innodb status获取死锁信息: ------------------------ LATEST DETECTED DEADLOCK ---------- ...
- C#中List按特定字段排序
有一个类,如Student,有学号.数学成绩.语文成绩, 存在List列表中,要将List按数学成绩排序,怎么办呢? List<Student> scores=GetScores(); s ...
- 窗口关闭时弹出内存不能为read
出现这个错误的原因是:某个指针类型的变量或对象,其记录的内容不可用,但进程对其进行了访问.可能由于:指针类型的变量或对象未被赋值就被使用:或者已经被正常释放后,又被访问所致.由于是在结束进程时报这样的 ...
- 前后台数据交换,printwriter、jsonobject、jsonarray、ajax请求,数据交换
后台代码: public void findByIDEquipment() { getResponse().setCharacterEncoding("UTF-8"); getRe ...
- Error in loadNamespace 的解决之道
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) 在构建比较复杂的环 ...