为了账号安全,请及时绑定邮箱和手机立即绑定

Django:如何从与用户相关的子查询集中获得一个独特的父列表?

Django:如何从与用户相关的子查询集中获得一个独特的父列表?

慕勒3428872 2021-04-05 08:27:33
这些是我的模型,其中Apps具有menu_items:class App(models.Model):    name = models.CharField(max_length=50)class Menu(models.Model):    name = models.CharField(max_length=120)    app = models.ForeignKey(App, on_delete=models.PROTECT)    url = models.CharField(max_length=120, null=True)    class Meta:        ordering = ['name', 'app']这是我的观点,有什么方法可以对其进行优化?class AboutView(TemplateView):    template_name = 'about.html'    def get_context_data(self, *args, **kwargs):        context = super(AboutView, self).get_context_data(*args, **kwargs)        menu_items = Access.objects.filter(user__id=self.request.user.id)        applist = []        for m in menu_items:            applist.append(m.menu.app.name)        apps = App.objects.filter(name__in=applist)        context = {            "menu_items": menu_items,            "apps": apps        }        return context这是我的模板,我重新排列了每个应用程序下的menu_items。<ul class="navbar-nav ml-auto">                {% for app in apps %}                    <li class="nav-item dropdown">                        <a class="nav-link" href="#" id="appMenu" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">                            {{ app.name }}                        </a>                        <div class="dropdown-menu dropdown-menu-left" aria-labelledby="appMenu">                            {% for item in menu_items %}                                {% if item.menu.app.name == app.name %}                                    <a class="dropdown-item" href="{{ item.menu.url }}">{{ item.menu.name }}</a>                                    {# href="{{ item.menu.url }} #}                                {% endif %}                            {% endfor %}                        </div>                    </li>                {% endfor %}            </ul>我希望有一个更好的方法来做到这一点。先感谢您。根据要求,这是访问模型class Access(models.Model):    menu = models.ForeignKey(Menu, on_delete=models.PROTECT)    user = models.ForeignKey(User, on_delete=models.PROTECT)
查看完整描述

2 回答

?
饮歌长啸

TA贡献1951条经验 获得超3个赞

我不会写一个完整的答案,因为我没有足够的时间并且无法立即测试代码。但是无论如何:您正在寻找的功能是:

  • 查找跨越关系的关系(另请参见关于多值关系的部分)

  • 相关描述符

  • prefetch_relatedPrefetch对象

结合所有这些功能应该可以解决您的问题。唯一的警告是Prefetch使用到目前为止我从未使用过的对象过滤菜单项,因此我无法确定它是否可以按预期工作。


查看完整回答
反对 回复 2021-04-13
?
MMMHUHU

TA贡献1834条经验 获得超8个赞

这可以删除app_list和“ for循环”

apps = App.objects.filter(menu__name=F('menu'))

@bruno desthuilliers,我仍在尝试了解预取


查看完整回答
反对 回复 2021-04-13
  • 2 回答
  • 0 关注
  • 138 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信