如何在 Django 中执行 Inner Join
要展示 Django 应用程序中多个表的互连数据,您可能会遇到以下需求执行内连接操作。通过利用 select_lated 方法,您可以轻松实现此目的。
考虑以下场景:您想要在 HTML 模板中显示出版物的城市、州和国家/地区名称。但是,这些详细信息存储在单独的表中。要使用内连接检索此信息,您可以使用 select_lated 方法,如下所示:
pubs = publication.objects.select_related('country', 'country_state', 'city')
此查询将生成类似于以下的 SQL 语句:
SELECT "publication"."id", "publication"."title", ..., "country"."country_name", ...
FROM "publication"
INNER JOIN "country" ON ( "publication"."country_id" = "country"."id" )
INNER JOIN "countrystate" ON ( "publication"."countrystate_id" = "countrystate"."id" )
INNER JOIN "city" ON ( "publication"."city_id" = "city"."id" )
检索到的值将自动转换为 ORM 模型实例。这允许您通过循环内各自的对象访问相关表值,如下所示:
{% for p in pubs %}
{{ p.city.city_name}} # p.city has been populated in the initial query
# ...
{% endfor %}
通过采用此技术,您可以有效地从多个表中获取数据并在 HTML 模板中呈现互连信息,同时避免预先选择的正向关系产生额外的数据库命中。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3