如何使用 select_lated 在 Django 中執行內連線?

Linda Hamilton
發布: 2024-10-29 21:26:02
原創
675 人瀏覽過

How to Perform an Inner Join in Django Using `select_related`?

如何在Django 中執行Inner Join

要在Django 應用程式中展示來自多個表的互連數據,您可能會遇到以下需求執行內連線操作。透過利用 select_lated 方法,您可以輕鬆實現此目的。

考慮以下場景:您想要在 HTML 範本中顯示出版物的城市、州和國家/地區名稱。但是,這些詳細資訊儲存在單獨的表中。要使用內連接檢索此信息,您可以使用select_lated 方法,如下所示:

<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>
登入後複製

檢索到的值將自動轉換為ORM 模型實例。這允許您透過循環內各自的物件存取相關表值,如下所示:

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

透過採用此技術,您可以有效地從多個表中獲取資料並在HTML 中呈現互連資訊模板,同時避免預選前向關係的額外資料庫命中。

以上是如何使用 select_lated 在 Django 中執行內連線?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板