Django ForeignKey 反向查询

大家使用 Django 创建模型的时候一定会经常使用 ForeignKey 来创建两个表格之间多对一的外键关系,例如B中有一个 models.ForeignKey(A) 。而当我们需要反向查询 A 中某个具体实例所关联的 B 时,可能会用到 A.B_set.all() 或 B.objects.filter(A) 这两种不同的方法。

不知道大家有没有也想过一个问题:当网站实际上线后,SEO强调页面加载速度,而当面对不断增大的请求量,这两种方法的哪一种速度更快?

@property在model中的妙用

from django.db import models

    class Person(models.Model):
        name = models.CharField(max_length=64)
        age = models.IntegerField()
        tel = models.CharField(max_length=64)

        @property
        def all_cars(self):
            return cars.all()

        @property
        def info(self):
            # re

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
foreign key的related_name是Django框架中常用的一个属性,用于指定关联模型的反向关系中的名称。它可以帮助我们更方便地在关联模型中访问相关的对象集合。 当我们在一个模型中定义了一个foreign key字段时,Django会自动为该字段添加一个related_name属性,默认值为关联模型的小写名称加上"_set"。这意味着我们可以通过关联模型对象的名称加上"_set"来访问该关联模型对象的集合。 然而,有时候我们可能希望使用更具有意义的名称来引用这些相关对象,而不是使用自动生成的默认名称。这就需要使用related_name属性了。 我们可以在定义foreign key字段时通过related_name属性来指定我们想要的反向关系的名称。例如,如果一个博客模型有一个外键指向用户模型,并且我们想要在用户模型中使用 "blogs" 来访问该用户发表过的博客列表,我们可以这样定义: class Blog(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='blogs') 这样一来,我们就可以通过 "user.blogs" 来访问该用户发表过的所有博客。 需要注意的是,related_name属性在一对一关系和多对多关系上也可以使用,用法与上面类似。不过在多对多关系中,如果我们指定了一个表名作为related_name,Django会使用这个表名的复数形式来作为反向关系的名称。 总之,foreign key的related_name属性非常有用,可以帮助我们更灵活地访问关联模型的对象集合。通过合理使用related_name属性,我们可以方便地在代码中获取到我们想要的相关对象。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值