نوشتن Query های SQL با Django (قسمت دوم[نگاهی به عملگر‌های SQL])

در این قسمت سعی بر آن داریم تا عملگرهای اصلی که در SELECT نوشته می‌شود را در Django بنویسیم. سعی بر آن است تا با مثال‌هایی بتوان سرعت بالای کار با این ORM را بررسی کرد.

Python/Djangoسعی شده تا لیستی از عملگرهای WHERE بررسی شوند.

برای کار با عملگرها در ابتدا نیاز است مثال‌های کوچکی برای خود SELECT زده شود.

مثال‌های ساده:

برنامه‌نویس نیاز دارد در حین کار با ORM برای دیباگ یکبار query ی که run می‌شود را ببیند تا با خروجی مقایسه کند. بدین منظور متغیر query به شکل زیر تهیه شده است:

خروجی:

در واقع بالا SELECT را با * یا کل فیلد‌ها صدا زدیم، اما اگر بخواهیم فیلد‌های خاصی بازگردند به صورت زیر عمل می‌کنیم:

و اگر query را پرینت بگیریم دیگر سایر فیلد‌ها وجود ندارند.

و خروجی دو خط کد بالا بدین صورت می‌شود:

در واقع query بدین صورت شد:

استفاده از WHERE:

تابع get فقط یک row برای شما برمی‌گرداند. به کد زیر دقت کنید:

کد بالا به دلیل اینکه داده SHIPPER بیشتر از یکبار در جدول وجود دارد خطای زیر را بر می‌گرداند:

کاربرد این تابع زمانی است که شما فقط یک row می‌خواهید برگردانید. مثال خوب این تابع در پی Primary Key ها می‌باشد.

به جای تابع get می‌توان از تابع filter برای حل این موضوع استفاده کرد که به تفصیل جلوتر خواهیم پرداخت.

به query زیر دقت کنید:

نکته: فرض بر این است که شما بنا بر مطلب قبلی داده‌ها را import کرده‌اید.

خروجی SQL بالا چنین می‌شود:

 

به تکه کد زیر دقت کنید:

 

حتی وقتی که فیلد query را پرینت بگیریم دقیقا SQL بالا پرینت می شود:

اما پارامتر تابع filter کمی عجیب به نظر می‌رسد و بهتر است در آن تعمق شود:

متعیری که ساخته شده، از ترکیب اسم فیلد درون مدل و دو ـ به همراه ترکیب عمگرها ساخته شده، همین مثال بالا یعنی emp_id__gte از ترکیب emp_id به علاوه دو ـ و به همراه عملگر مورد نظر است. عملگر مورد نظر یعنی Less Than Equal ، در SQL می‌شود => که به معنای کوچکتر مساوی است. درون آن هم مساوی دیده می‌شود و هم مقدار اگر به کد SQL مورد نظر نگاه کنید، کاملا ترکیب پارامتر filter توصیف می‌شود.

فرمتی که تابع filter دارد به دو حالت است:

۱. یا متغیر به همراه دو ـ و به همراه یک عملگر

۲. یا متغیر تنها

تابع فیلتر از عملگر‌های فرترنی که در شل اسکریپت هم استفاده می‌شوند استفاده می‌کند:

  • gt به معنای Great Than
  • lt به معنای Less Than
  • e به معنای Equal

البته جلوتر ترکیب‌های بیشتری به غیر از دو ترکیب بالا خواهیم دید.

نکته: برای مساوی نیاز نیست از یک ترکیب استفاده کنیم، فقط کافیست اسم فیلد نوشته شد.

یک سوالی که همیشه مطرح است ، چگونگی ساخت AND , OR و NOT می‌باشد. برای ساختن این سه عنصر جنگو تابع Q را معرفی کرده است. به کد زیر دقت کنید:

تابع Q همانند filter شرط می‌پذیرد. با سه عملگر زیر می‌توان NOT ، AND و OR را پیاده‌سازی کرد:

  • ~ به معنی عملگر NOT
  • | به معنی عملگر OR
  • & به معنی عملگر AND

در کد بالا هر چه emp_id که از عدد فوق بزرگتر نباشد را با هر row ی که position آن برابر SHIPPER باشد AND می‌کنیم، به طوری که خروجی SQL آن به صورت زیر می‌شود:

خروجی QuerySet آن نیز به صورت زیر می‌شود:

 

استفاده از LIKE:

برای استفاده از LIKE ، می‌توان از ترکیب‌های زیر استفاده نمود:

  • contains
  • icontains
  • startswith
  • istartswith
  • endswith
  • iendswith
  • exact
  • iexact

نکته:  وقتی از i در اول هر کدام استفاده می‌شود به معنی case-insensitive می‌باشد.

به تکه کد‌های زیر و SQL موجود در زیر آن دقت کنید:

 

در کد بالا از %mystring% استفاده شد.

در کد بالا هر رشته‌ای که با حرف s شروع می‌شود مد نظر است.

در کد بالا هر رشته‌ای که با حرف N  خاتمه می‌یابد مد نظر است.

در کد بالا عملگر تساوی مهم است.

نکته: برای NOT کردن هر کدام از Query های بالا می‌توانید از تابع Q به صورتی که قبل‌تر گفته شد استفاده کنید.

 

مطالب مربوط به ORM جنگو ادامه خواهند داشت. منتظر باشید.

 

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *