微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Django 外键关系应该是用户到模型还是模型到用户?

如何解决Django 外键关系应该是用户到模型还是模型到用户?

我是 django 的新手,正在尝试制作一个电子商务网站以供练习。有一个 Cart 模型,它当前具有指向 UserForeignKey。哪种方式更有效率?

我应该创建一个将 Cart 作为外键的 UserProfile 模型还是应该保持这样?

我认为前者应该更快,因为当我向用户显示购物车时,如果我保持原样,它将必须搜索和过滤所有购物车。但是我正在观看的教程正在设置他们的模型,其中 Cart 具有用户的外键。

解决方法

我在评论中写了这个,但结果证明它超过了允许的字符数。

回答您的问题:Can you explain how is it more efficient as it will have to search through all the carts to find the user's cart. Do websites with big database also have it set up like this?

是的,他们有。如果您将购物车作为 FK 添加到 UserProfile 中,它不应该更快,因为它只保存对购物车实例的引用。您仍然需要转到 Cart 表并检索相关行。您必须小心的是控制对数据库进行的查询数量。要跟踪它,您可以使用 django-debug-toolbar,或使用 shell 对其进行调试。

from django.db import connection
queries=connection.queries

print(f"QUERY: {len(queries)}")

然后检查查询的长度及其详细信息以进行调试并使其更快。此外,请尽可能使用 select_relatedprefetch_related,这将显着减少查询次数。

Django 调试工具栏看起来像这样

ddt

当您点击 SQL 时,您将看到所有查询的详细信息,并能够看到重复的查询。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。