हल: django मॉडल प्रश्न

Django मॉडल प्रश्नों के साथ मुख्य समस्याओं में से एक यह है कि वे बहुत वर्बोज़ हो सकते हैं। उदाहरण के लिए, यदि आप किसी दिए गए ब्लॉग में सभी लेख खोजना चाहते हैं, तो आपको इस तरह की क्वेरी का उपयोग करने की आवश्यकता होगी:

लेख = Blog.objects.all ()

यदि आप उन सभी लेखों को खोजना चाहते हैं जो पिछले महीने प्रकाशित हुए हैं, तो आपको इस तरह की एक क्वेरी का उपयोग करने की आवश्यकता होगी:

article_published_in_the_last_month = Blog.objects.filter(published=True)

There are a number of ways to query a Django model. The simplest way is to use the Model.objects.all() method, which will return all objects for that model.

If you want to filter the queryset, you can use the Model.objects.filter(**kwargs) method, where kwargs is a dictionary of field names and values to filter on. For example, if you only wanted objects with a certain value for the 'name' field, you could do:

Model.objects.filter(name='value')

If you want to get a single object from the queryset, you can use the Model.objects.get(**kwargs) method, which will return the first object that matches the given criteria. For example, if you wanted to get an object with a particular 'id' value:

Model.objects.get(id=1)

यदि आप क्वेरीसेट को ऑर्डर करना चाहते हैं, तो आप Model.objects.order_by(field_name) विधि का उपयोग कर सकते हैं, जो दिए गए फ़ील्ड द्वारा आरोही क्रम में क्वेरीसेट को ऑर्डर करेगा। अवरोही क्रम में ऑर्डर करने के लिए आप '-' उपसर्ग का भी उपयोग कर सकते हैं:

Model.objects.order_by('-name')

क्वेरीसेट क्या है

एक क्वेरीसेट संबंधित मॉडलों का संग्रह है जिसे एक साथ पूछताछ की जा सकती है। यह मॉडल को एक साथ समूहित करने का एक सुविधाजनक तरीका है ताकि आप उन्हें एक इकाई के रूप में आसानी से क्वेरी कर सकें।

क्वेरी एक्सप्रेशन

Django में डेटा को फ़िल्टर करने के लिए क्वेरी एक्सप्रेशन एक शक्तिशाली तरीका है। यह SQL क्वेरी में WHERE क्लॉज के समान है, लेकिन इसका उपयोग किसी भी मॉडल ऑब्जेक्ट के साथ किया जा सकता है।

उदाहरण के लिए, आप "कैसे करें" से शुरू होने वाले शीर्षक वाले सभी लेखों को खोजने के लिए एक क्वेरी एक्सप्रेशन का उपयोग कर सकते हैं:

article.filter(title__startswith='How to')

क्वेरी सेट एपीआई संदर्भ

QuerySet API किसी मॉडल के फ़ील्ड और संबद्ध डेटा को क्वेरी करने का एक तरीका प्रदान करता है। एपीआई को एसक्यूएल सेलेक्ट स्टेटमेंट के बाद तैयार किया गया है, और आपको यह निर्दिष्ट करने की अनुमति देता है कि आप किन क्षेत्रों को पुनः प्राप्त करना चाहते हैं, आप उन्हें किस क्रम में लौटाना चाहते हैं, और डेटा की कितनी पंक्तियाँ आप वापस करना चाहते हैं।

QuerySet API का उपयोग करने के लिए, पहले एक मॉडल ऑब्जेक्ट बनाएँ:

django.db आयात मॉडल वर्ग MyModel (models.Model) से: नाम = मॉडल। चारफिल्ड (max_length = 30)

फिर एक क्वेरी ऑब्जेक्ट बनाएं:

query = MyModel.objects.create_query() query.select('name').order_by('-name')

संबंधित पोस्ट:

टिप्पणी करें