1.作用

将app名称与其中表关系进行保存

在models创建表时,关联到ContentType并不会产生实际的字段

2.使用

在models中代码

from django.db import models

from django.contrib.contenttypes.fields import GenericRelation
# Create your models here.
class Courser(models.Model):
    title = models.CharField(max_length=32)
    #这里的object_id_field有默认值object_id,content_type_field有默认值content_type
    #如果PricePolicy的字段名不是和默认值一样,那就要和下面一样,和PricePolicy表里的字段名对上
    #不需要做数据库迁移,不会生成字段,只是方便用来查询
    policy = GenericRelation('PricePolicy', object_id_field='course_id', content_type_field='table_id')

    def __str__(self):
        return self.title

class DegreeCourser(models.Model):
    title = models.CharField(max_length=32)
    policy = GenericRelation('PricePolicy', object_id_field='course_id', content_type_field='table_id')

    def __str__(self):
        return self.title

from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
from django.contrib.contenttypes.models import ContentType

class PricePolicy(models.Model):
    price = models.DecimalField(max_digits=8, decimal_places=2)
    period = models.CharField(max_length=32)
    # 强调,如果是外部导入的表,不能带引号
    # 表的id
    table_id = models.ForeignKey(to=ContentType)
    # 课程id
    course_id = models.IntegerField()
    # PositiveIntegerField()---正整数
    # 如果表id字段名叫:content_type,课程id字段名叫:object_id,GenericForeignKey()就不需要传参
    # 不需要做数据库迁移,也不会在数据库生成字段,只用来查询和插入
    # 如果保存的时候,只需要传content_obj这个字段,内部自动会保存table_id,course_id

    content_obj = GenericForeignKey('table_id', 'course_id')

在views中代码

from django.shortcuts import render,HttpResponse,reverse,redirect

from django.contrib.contenttypes.models import ContentType

# Create your views here.
from app01 import models
def test(request):
    #为django专题课添加三个价格策略
    # course=models.Courser.objects.get(pk=1)
    #
    # table_id=ContentType.objects.get(model='courser')
    # ret=models.PricePolicy.objects.create(price=9.9,period='1个月',table_id=table_id,course_id=course.pk)
    # ret=models.PricePolicy.objects.create(price=9.9,period='2个月',table_id=table_id,course_id=course.pk)
    # ret=models.PricePolicy.objects.create(price=9.9,period='3个月',table_id=table_id,course_id=course.pk)

    #使用contenttype插入,其实就是根据course,查出course.pk,course所在表的表名,本质上还是做了上面的操作
    # course = models.Courser.objects.get(pk=2)
    # ret=models.PricePolicy.objects.create(price=9.9,period='1个月',content_obj=course)
    # ret=models.PricePolicy.objects.create(price=19.9,period='2个月',content_obj=course)
    # ret=models.PricePolicy.objects.create(price=29.9,period='3个月',content_obj=course)
    #
    #给学位课加一个价格策略
    # degre_course=models.DegreeCourser.objects.get(pk=1)
    # models.PricePolicy.objects.create(price=19999.9,period='5个月',content_obj=degre_course)

    #查询所有价格策略,并且显示对应的课程名称
    # ret=models.PricePolicy.objects.all()
    # for i in ret:
    #     print(type(i.content_obj))
    #     print(i.content_obj)

    #查询Django所有的价格策略
    course=models.Courser.objects.get(pk=1)
    course_policy=course.policy.all()
    for i in course_policy:
        print(i.period)
    return HttpResponse('ok')

content_type的更多相关文章

  1. Django content_type 简介及其应用

    在网上看到 django ORM 有一个 content_type 字段表的应用,这张表不是我们通过建立model类添加的,而是django自动帮我们生成的,具体的作用先简单的举个例子给大家介绍一下. ...

  2. $Django content_type组件 缓存组件

    1  content_type组件(只能方便插入添加) 需求:课程,学位课(不同的课程字段不一样),价格策略 #免费课 class Free_classes (models.Model): id = ...

  3. AI-跨域、垃圾回收、content_type组见、接口处理

    AI-跨域.垃圾回收.content_type组见.接口处理 跨域 为什么有跨域?什么时候遇见的?答:由于浏览器的同源策略 阻止ajax请求 不阻止src请求:在测试时,项目上线后不会遇见跨域.源:协 ...

  4. 11.8Django中的组件content_type

    2018-11-8 18:59:11 在Django中已经有一个contenttype这个组件,并且在python manage.py makemigrations 和migrate的时候,一起在数据 ...

  5. django之content_type

    什么是content type:django内置的一个组件,这个组件帮忙做连表的操作.(混搭连表) 适用场景:适用于一张表与多张表同时做关联的时候.直接导入就可以使用了. 关联数据库说有的表:让我们可 ...

  6. Django 组件content_type

    content type: django内置组件,这个组件帮忙做连表操作(混搭连表) 适用场景:适用于一张表与多张表同时做关联的时候.直接导入就可以使用了. 关联数据库所有的表:可以快速插入数据,并且 ...

  7. django model content_type 使用

    一.关于content_type 使用 1.引入模块在models from django.db import models from django.contrib.contenttypes.mode ...

  8. 11.关于django的content_type表

    ****** Django的contenttype表中存放发的是app名称和模型的对应关系 contentType使用方式 - 导入模块 from django.contrib.contenttype ...

  9. Django中的content_type表

    models.py from django.db import models from django.contrib.contenttypes.models import ContentType # ...

随机推荐

  1. JS控制只能输入数字并且最多允许小数点两位

    直接上代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  2. day_6.6 py

    Tftp 下载器演示 2018-6-6 14:11:09 #!/usr/bin/env python #!--*--coding:utf-8 --*-- #!@Time :2018/6/6 11:55 ...

  3. 使用 tabindex 改变Tab 键顺序

    使用 tabindex原文 https://developers.google.cn/web/fundamentals/accessibility/focus/using-tabindex 在表单上使 ...

  4. Nodejs----登录验证

    1. 写在前面 当我们登录了一个网站,在没有退出登录的情况下,我们关闭了这个网站 ,过一段时间,再次打开这个网站,依然还会是登录状态.这是因为,当我们登录了一个网站,服务器会保存我们的登录状态,直到我 ...

  5. HTML滚动文字代码 marquee标签

    看到一个HTML滚动文字代码 marquee标签的内容,非常全面,而且觉得有点意思,可以让大家为自己博客或者网站设置一个漂亮的滚动文字. 以下是原文: <marquee style=" ...

  6. Nand: OOB BBT ECC PEB LEB

    OBB: 例如Samsung K9F1208U0B,数据存储容量为64MB,采用块页式存储管理.8个I/O 引脚充当数据.地址.命令的复用端口.芯片内部存储布局及存储操作特点: 一片Nand flas ...

  7. 201621123049 《Java程序设计》第1周学习总结

    一. 本周学习总结 JDK,JRE,JVM等基本概念 怎么学好java???不,是怎么才能应用好??? 编程!编程!编程! 思考->设计->解决问题 二. 书面作业 1.虚拟机 1.1 执 ...

  8. 使用hive分析nginx访问日志方法

    以下案例是使用hive分析nginx的访问日志案例,其中字段分隔通过正则表达式匹配,具体步骤如下: 日志格式: 192.168.5.139 - - [08/Jun/2017:17:09:12 +080 ...

  9. centos 安装oracle 报Checking swap space: 0 MB available, 150 MB required. Failed <<<<

    1 系统环境 centos 6.5 oracle 11g 内存 16G 硬盘 ssd 250G 2 运行安装命令: [oracle@localhost database]$ ./runInstalle ...

  10. #include<stdio.h> #include "stdio.h"

    https://baike.baidu.com/item/#include <stdio.h> #include <stdio.h> 编辑 #include<stdio. ...