」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 select_lated 在 Django 中執行內連線?

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

發佈於2024-11-04
瀏覽:663

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

如何在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