• Django框架(二十七)—— ContentType组件


    ContentType组件

    一、什么是ContentType组件

    contentType是Django内置的组件,可以方便我们快速的连表查询。

    • 可以追踪项目中所有app和model的对应关系,并记录在ContentType表中
    • models.py文件的表结构写好后,通过makemigrations和migrate两条命令迁移数据后,在数据库中会自动生成一个django_content_type表:

    • 每当我们创建了新的model并执行数据库迁移后,ContentType表中就会自动新增一条记录
    • 加的几个字段都不会在数据库中生成,它只是用来查询、插入

    二、使用ContentType

    GenericRelation 只是为了方便查询,不会再表中产生该字段

    GenericForeignKey 只是为了方便保存

    from django.contrib.contenttypes.models import ContentType
    from django.contrib.contenttypes.fields import GenericForeignKey,GenericRelation
    
    class Couser(models.Model):
        title = models.CharField(max_length=32)
        # 不需要做数据库迁移,这个字段不会在数据表中生成,只用来方便查询
        policy = GenericRelation('PricePolicy', object_id_field='course_id', content_type_field='table_id')
    
    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)
        # table_bb = models.ForeignKey(to='contenttypes.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')
        
    

    三、使用场景总结

    1、价格策略系统

    对于同一种商品可能有很多种价格,例如一个某课程的不同周期的价格是不一样的

    2、优惠券系统

    对于商品,有很多种优惠券,例如满200减30,满400减80……

  • 相关阅读:
    计总与排名SUM和RANK函数
    计算获取最小值和最大值
    列值中获取第一个非空的值
    连续数字使用连接符替换
    展开中断或忽略的序号
    以连接字符截取字符串
    逗号分割字符串经存储过程存入数据表中
    符号分割的字符串转换为XML
    MS SQL Server的STRING_SPLIT和STRING_AGG函数
    MS SQL Server的LTRIM,RTRIM和TRIM函数
  • 原文地址:https://www.cnblogs.com/linagcheng/p/10170346.html
Copyright © 2020-2023  润新知