Django में इनर जॉइन कैसे निष्पादित करें
अपने Django एप्लिकेशन में एकाधिक तालिकाओं से इंटरकनेक्टेड डेटा प्रदर्शित करने के लिए, आपको आवश्यकता का सामना करना पड़ सकता है आंतरिक जुड़ाव ऑपरेशन करने के लिए। चयन_संबंधित पद्धति का लाभ उठाकर, आप इसे आसानी से प्राप्त कर सकते हैं।
निम्नलिखित परिदृश्य पर विचार करें: आप एक HTML टेम्पलेट में किसी प्रकाशन के शहर, राज्य और देश के नाम प्रदर्शित करना चाहते हैं। हालाँकि, ये विवरण अलग-अलग तालिकाओं में संग्रहीत हैं। इनर जॉइन का उपयोग करके इस जानकारी को पुनः प्राप्त करने के लिए, आप निम्नानुसार चयन_संबंधित विधि का उपयोग कर सकते हैं:
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" )
पुनर्प्राप्त मान स्वचालित रूप से ओआरएम मॉडल उदाहरणों में परिवर्तित हो जाएंगे। यह आपको एक लूप के भीतर उनके संबंधित ऑब्जेक्ट के माध्यम से संबंधित तालिका मानों तक पहुंचने की अनुमति देता है, जैसा कि नीचे दिखाया गया है:
{% 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