首页 >数据库 >mysql教程 >如何从 Django 的相关表中高效检索城市、州和国家/地区数据?

如何从 Django 的相关表中高效检索城市、州和国家/地区数据?

Barbara Streisand
Barbara Streisand原创
2024-10-29 09:28:02817浏览

How Can I Efficiently Retrieve City, State, and Country Data from Related Tables in Django?

Django 中的内连接多个表

要显示存储在单独表中的出版物的城市、州和国家/地区,您可以可以使用 select_lated() 方法在 Django 中执行内部联接。

<code class="python">pubs = publication.objects.select_related('country', 'country_state', 'city')</code>

此查询将生成类似于以下的 SQL 语句:

<code class="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" )</code>

返回的 pubs 游标包含带有预先填充相关表的值,使您无需额外的数据库命中即可访问它们:

<code class="html">{% for p in pubs %}
    {{ p.city.city_name}}  # p.city has been populated in the initial query
    # ...
{% endfor %}</code>

这种方法非常高效,可以防止不必要的查询来检索相关数据。

以上是如何从 Django 的相关表中高效检索城市、州和国家/地区数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn