ORM 多对多表操作

关系表
在这里插入图片描述

模型创建

在这里插入图片描述
查看数据库
在这里插入图片描述

增加

增加老师数据
在这里插入图片描述
在这里插入图片描述

查询

在这里插入图片描述

更改

在这里插入图片描述

删除

在这里插入图片描述

聚合查询 avg sum max min count

在这里插入图片描述
通过aggregate调用聚合函数

aggregate () 是一个queyset的方法,意思是:返回一个包含数据的键值对的字典

键名:聚合值的表示符号,值:聚合函数计算的结果。

def jttest(request):
    data = Person.objects.all().aggregate(Avg("age"))
    print(data)
    data = Person.objects.all().aggregate(avg_age = Avg("age"),sum_age = Sum("age"))
    print (data)

    return HttpResponse("集合查询")

F对象 Q对象

F对象: 用于比较同一个模型中的两个字段的值
在这里插入图片描述

Q对象

用于处理多条件中的逻辑关系   and or not
def Qtest(request):

    ###   and
    data = Book.objects.filter(num=10,salled=100).all()
    print (data)
    # and 关系
    data = Book.objects.filter(Q(num__gt=10)&Q(salled=100)).all()
    print(data)
    ## or
    data =Book.objects.filter(Q(num__gt=10)|Q(salled=100)).all()
    print (data)
    ## not
    data = Book.objects.filter(~Q(num=10)|~Q(salled=100)).all()
    print (data)

    return HttpResponse("Q obj test")

站点模型

在这里插入图片描述

注册超级用户

createsuperuser
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Django ORM 中实现多态一对多关系,可以使用 Django ContentTypes 库。该库允许您为任何模型创建一个通用的外键字段,该字段可以引用另一个模型的实例,而无需直接指定模型。 具体实现步骤如下: 1. 首先,安装 Django ContentTypes 库:`pip install django-contenttypes` 2. 在 models.py 中定义多态模型: ```python from django.contrib.contenttypes.fields import GenericForeignKey from django.contrib.contenttypes.models import ContentType from django.db import models class ParentModel(models.Model): name = models.CharField(max_length=50) class ChildModel1(models.Model): parent = models.ForeignKey(ParentModel, on_delete=models.CASCADE) # 定义通用外键 content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE) object_id = models.PositiveIntegerField() content_object = GenericForeignKey('content_type', 'object_id') class ChildModel2(models.Model): parent = models.ForeignKey(ParentModel, on_delete=models.CASCADE) # 定义通用外键 content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE) object_id = models.PositiveIntegerField() content_object = GenericForeignKey('content_type', 'object_id') ``` 3. 在视图函数中,可以根据需求获取多态模型的实例: ```python from django.contrib.contenttypes.models import ContentType # 获取 ParentModel 的所有子模型 child_models = [ChildModel1, ChildModel2] # 获取 ParentModel 的实例 parent = ParentModel.objects.get(id=1) # 获取 ParentModel 的所有子模型实例 child_instances = [] for child_model in child_models: content_type = ContentType.objects.get_for_model(child_model) child_instances += child_model.objects.filter(content_type=content_type, object_id=parent.id) # 对子模型实例进行操作 for child_instance in child_instances: # ... ``` 以上就是在 Django ORM 中实现多态一对多关系的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值