Django ContentType(ORM操作)
ContentType-设计课程表
# 数据:
"""
免费课:Python入门
学位课:Python全栈 价格策略:
Linux入门 7 0
Python入门 7 0
Python入门 14 9.9
Python入门 30 199
Python全栈 180 18888
Python全栈 240 23888
""" # 设计
""" 不合理
# Course表
# id name type price_policy normal_course degreecourse
1 Linux入门 免费课 1 有 空
2 Python入门 免费课 2 有 空
3 Python入门 免费课 3 有 空
4 Python全栈 学位课 4 空 有 # PricePolicy表
# id day price
1 7 0
2 7 0
3 14 9.9
4 180 18888
""" """
# Course表
# id name normal_course(该表独有的字段)
1 Linux入门 数据
2 Python入门 数据 # DegreeCourse表
# id name degreecourse(该表独有的字段)
1 Python全栈 数据 # PricePolicy表
# id day price couse_id course_type
1 7 0 1 免费课
2 7 0 2 免费课
3 14 9.9 2 免费课
4 180 18888 1 学位课 # 问题点:课程相关表的 主键 与 表名 两个信息 在价格策略表中
# 问题1:couse_id数据不具备唯一性,不能成为外键
# 问题2:couse_id与course_type能否生成联合唯一外键?
-- course_type是与表名有联系,并不是 课程相关表 的表字段
-- couse_id与course_type能不能保证唯一性
""" # 解决方案
"""
# Course表
# id name normal_course(该表独有的字段)
1 Linux入门 数据
2 Python入门 数据 # DegreeCourse表
# id name degreecourse(该表独有的字段)
1 Python全栈 数据 # PricePolicy表
# id day price couse_id course_type(外键)
1 7 0 1 1
2 7 0 2 1
3 14 9.9 2 1
4 180 18888 1 2 # TableName表 => ContentType
id table_name
1 course
2 degree_course ContentType解决的问题:一个表的两个字段与另外两张表有关联(关联关系是交叉的)
"""
ContentType-开发使用
"""
# Course表
# id name
1 Python入门 # DegreeCourse表
# id name
1 Python全栈 # PricePolicy表
# id day price couse_id course_type(外键)
1 7 0 1 1
2 14 9.9 1 1
3 180 18888 1 2 # ContentType表
id table_name
1 course
2 degreecourse
"""
models.py
from django.db import models from django.contrib.contenttypes.fields import GenericRelation class Course(models.Model):
name = models.CharField(max_length=32)
# price_policy = GenericRelation(to='PricePolicy',object_id_field='object_id',content_type_field='content_type')
# 当你的类GenericRelation关联的表PricePolicy中的字段和(object_id_field='object_id', content_type_field='content_type'),
# 字段名字完全一致时可以省略object_id_field和content_type_field的参数
price_policy = GenericRelation(to='PricePolicy') # 用户连表查询,不会在数据库中产生字段 class DegreeCourse(models.Model):
name = models.CharField(max_length=32)
price_policy = GenericRelation(to='PricePolicy') from django.contrib.contenttypes.models import ContentType
from django.contrib.contenttypes.fields import GenericForeignKey class PricePolicy(models.Model):
day = models.IntegerField()
price = models.CharField(max_length=8)
# course_id = models.IntegerField() # 某课程表的主键,但是不具备唯一性,所以只能用IntegerField
# course_type = models.CharField(max_length=16) # 一会儿要改成外键
# course_type = models.ForeignKey(to=ContentType, null=True)
# model_object = GenericForeignKey(ct_field='course_type', fk_field='course_id')
object_id = models.IntegerField()
content_type = models.ForeignKey(to=ContentType, null=True)
# 改操作只用于ContentType连表查询,不会产生表字段,就是关联课程表的对象
# 当你在此类中有和GenericForeignKey所需要的参数(ct_field='content_type', fk_field='object_id'),
# 即ct_field和fk_field参数所需的字段名字完全一致时可以胜率这两个参数的值
model_object = GenericForeignKey()
Views.py
from django.shortcuts import HttpResponse
from api import models def add_course(request):
# 为python入门 免费课增加两条价格策略
# course = models.Course.objects.filter(pk=1).first()
# content_type = models.ContentType.objects.filter(model='course').first()# course应该写活
# models.PricePolicy.objects.create(day=7, price=0, course_id=course.pk, content_type=content_type)
# course = models.Course.objects.filter(pk=1).first()
# print(course._meta.model_name) # 为model对象表名小写
# content_type = models.ContentType.objects.filter(model=course._meta.model_name).first()
# models.PricePolicy.objects.create(day=14, price=9.9, course_id=course.pk, content_type=content_type) # 上述方法是在models.py中PricePolicy类中的course_id和course_type字段没有注释之前的方法
# 为Python全栈 学位课程添加一条价格策略 采用ContentType来实现
# degree_course = models.DegreeCourse.objects.filter(pk=1).first()
# models.PricePolicy.objects.create(day=180, price=18888, model_object=degree_course) # 查找所有课程的所有价格策略
# price_policy_list = models.PricePolicy.objects.all()
# for price_policy in price_policy_list:
# print(price_policy.model_object.name, price_policy.day, price_policy.price) # 查看Python入门的所有价格策略
course = models.Course.objects.filter(pk=1).first()
price_policy_list = course.price_policy.all()
for price_policy in price_policy_list:
print(course.name, price_policy.day, price_policy.price)
return HttpResponse('ok')
Django ContentType(ORM操作)的更多相关文章
- Django之ORM操作
Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...
- Django之ORM操作(聚合 分组、F Q)
Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作. 键的名 ...
- Django之ORM操作(***)
Django之ORM操作(***) http请求的流程: url--> 视图view(模板+数据库) --> ORM的功能: 可以转换SQL语句,并做操作. ORM操作数据表: -创建表: ...
- 【Django】ORM操作#2
目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...
- 【Django】ORM操作#1
目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...
- django的orm操作优化
django的orm操作优化 models.py from django.db import models class Author(models.Model): name = models.Char ...
- Django中ORM操作
ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...
- Django的ORM操作
ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...
- Django之ORM操作总结
Django之ORM总结 表结构 from django.db import models # 一对多:班级与学生 # 多对多:班级与老师 # Create your models here. #创建 ...
随机推荐
- 『JWT』,你必须了解的认证登录方案
我是风筝,公众号「古时的风筝」,一个兼具深度与广度的程序员鼓励师,一个本打算写诗却写起了代码的田园码农! 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在 ...
- three.js 制作逻辑转体游戏(下)
上一篇已经对绕非定轴转动有所了解,这篇郭先生继续说一说逻辑转体游戏的制作,这部分我们同样会遇到一些小问题,首先是根据数据渲染陷阱和目标区域,然后是对可以转动的判定,最后是获胜的判定. 1. 根据数据渲 ...
- 进阶6:连接查询 二、sql99语法
#二.sql99语法/*语法: select 查询列表 from 表1 别名 [连接类型] join 表2 别名 on 连接条件 [where 筛选条件] [group by 分组] [having ...
- Solon详解(五)- Solon扩展机制之Solon Plugin
Solon 中也有一种非常解耦的扩展机制:Solon Plugin.这种扩展机制和Spring Factories很像,和SPI也很像. 一.Solon 中的扩展机制 在Solon的扩展插件加载机制, ...
- c++右值引用和转移构造函数
int &&i = ; //i绑定到了右值1 int b = ; cout << i << endl; //输出1 i = b; cout << i ...
- 2020.5.28 第八篇 Scrum冲刺博客
Team:银河超级无敌舰队 Project:招新通 项目冲刺集合贴:链接 目录 一.每日站立会议 1.1 会议照片 1.2 项目完成情况 二.项目燃尽图 三.签入记录 3.1 代码/文档签入记录 3. ...
- 团队作业3 需求改进&系统设计(银河超级无敌舰队)
目录 一.需求&原型改进 1. 需求改进 2. 修改说明书 3.功能分析 4. 调整WBS及计划 二.系统设计 1. 总体设计 2. 数据库设计 3.社团设计 三.Alpha任务分配计划 1. ...
- 能卖课 会带货的CRMEB知识付费系统v1.30来了
CRMEB知识付费系统是众邦科技在疫情肆虐,国家危难时开源发布的一款产品,它的诞生是众邦人爱国情怀的一次释放,更是众邦人用技术为人们带来美好生活的一次有效实践. 知识付费系统从2020年3月发布v1. ...
- Netty学习笔记-入门版
目录 Netty学习笔记 前言 什么是Netty IO基础 概念说明 IO简单介绍 用户空间与内核空间 进程(Process) 线程(thread) 程序和进程 进程切换 进程阻塞 文件描述符 文件句 ...
- leetcode刷题-83删除排序链表中的重复元素
题目 给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次. 示例 1: 输入: 1->1->2 输出: 1->2 实现 # Definition for singly-li ...