فهرست سرفصل‌های Django
خانه (Home) مقدمه (Intro) شروع به کار (Get Started) ساخت محیط مجازی (Create Virtual Environment) نصب (Install Django) ساخت پروژه (Create Project) ساخت اپ (Create App) ویوها (Views) آدرس ها (URLs) قالب ها (Templates) مدل ها (Models) افزودن داده (Insert Data) به روزرسانی داده (Update Data) حذف داده (Delete Data) به روزرسانی مدل (Update Model) آماده سازی قالب و ویو (Prep Template and View) افزودن لینک به جزئیات (Add Link to Details) افزودن قالب مادر (Add Master Template) افزودن صفحه ایندکس اصلی (Add Main Index Page) قالب 404 (404 Template) افزودن ویوی تست (Add Test View) پنل مدیریت (Admin) ساخت کاربر (Create User) افزودن مدل ها (Include Models) تنظیم List Display (Set List Display) به روزرسانی اعضا (Update Members) افزودن اعضا (Add Members) حذف اعضا (Delete Members) متغیرها (Variables) تگ ها (Tags) شرط if/else (If Else) حلقه for (For Loop) کامنت (Comment) include (Include) معرفی QuerySet (QuerySet Introduction) متد get (QuerySet Get) فیلتر (QuerySet Filter) مرتب سازی (QuerySet Order By) افزودن فایل های استاتیک (Add Static Files) نصب WhiteNoise (Install WhiteNoise) جمع آوری فایل های استاتیک (Collect Static Files) افزودن فایل های استاتیک سراسری (Add Global Static Files) افزودن استایل به پروژه (Add Styles to the Project) مقدمه (PostgreSQL Intro) ساخت حساب AWS (Create AWS Account) ساخت دیتابیس در RDS (Create Database in RDS) اتصال به دیتابیس (Connect to Database) افزودن اعضا (Add Members) Elastic Beanstalk (EB) ساخت requirements.txt (Create requirements.txt) ساخت django.config (Create django.config) ساخت فایل zip (Create .zip File) استقرار با EB (Deploy with EB) به روزرسانی پروژه (Update Project) افزودن فیلد slug (Add Slug Field) افزودن Bootstrap 5 (Add Bootstrap 5) مرجع تگ های قالب (Template Tag Reference) مرجع فیلترها (Filter Reference) مرجع Field Lookups (Field lookups Reference) کامپایلر (Compiler) تمرین ها (Exercises) آزمون (Quiz) سرفصل (Syllabus) برنامه مطالعه (Study Plan) سرور (Server) گواهینامه (Certificate)
نتیجه‌ای برای جستجو یافت نشد.
Django

Django — فیلتر (QuerySet Filter)

آخرین بروزرسانی: 1404/08/20

فیلتر (QuerySet Filter)

می خواهیم «فیلتر QuerySet» را ساده کنیم. فیلتر یعنی فقط نتایج دلخواه را برگردانیم. QuerySet فهرست نتایج دیتابیس است. سپس با شرط ها، خروجی را دقیق می کنیم. مثل پیدا کردن دانش آموزانی که اسمشان «امیـل» است.

فیلتر ساده با filter()

filter() با آرگومان های کلیدی کار می کند. هر آرگومان یک شرط است. نتیجه فقط ردیف های مطابق است.

mydata = Member.objects.filter(firstname='Emil').values()

مشاهده در ادیتور

ترکیب شرط ها: AND

چند شرط را با کاما بده. این یعنی AND. هر دو شرط باید درست باشند.

mydata = Member.objects.filter(lastname='Refsnes', id=2).values()

مشاهده در ادیتور

ترکیب شرط ها: OR با دو روش

یا دو فیلتر را با | ادغام کن. یا از Q استفاده کن. Q برای شرط های پیچیده عالی است.

mydata = Member.objects.filter(firstname='Emil').values() | Member.objects.filter(firstname='Tobias').values()

مشاهده در ادیتور

from django.http import HttpResponse
from django.template import loader
from .models import Member
from django.db.models import Q

def testing(request):
  mydata = Member.objects.filter(Q(firstname='Emil') | Q(firstname='Tobias')).values()
  template = loader.get_template('template.html')
  context = {
    'mymembers': mydata,
  }
  return HttpResponse(template.render(context, request))

مشاهده در ادیتور

Field Lookup ها: نحو حرفه ای

برای شرط های خاص از «Field Lookup» استفاده کن. شکل کلی: field__lookup. دو زیرخط اجباری است.

mydata = Member.objects.filter(firstname__startswith='L').values()

مشاهده در ادیتور

نکته: __startswith مثل LIKE 'L%' است. بنابراین نتایج با حرف L شروع می شوند.

گام های عملی

  1. یک QuerySet ساده بگیر.
  2. شرط ها را با filter() اضافه کن.
  3. برای AND، آرگومان ها را با کاما بده.
  4. برای OR، از | یا Q استفاده کن.
  5. در قالب، نتایج را با حلقه for نشان بده.

جمع بندی سریع

  • filter() نتایج را محدود می کند.
  • کاما یعنی AND.
  • | یا Q یعنی OR.
  • field__lookup شرط های خاص می سازد.
  • __startswith مثل LIKE 'X%' عمل می کند.

ادامه مسیر: صفحه متد get جنگو را برای مقدمات ببین. سپس با مرتب سازی QuerySet آشنا شو. همچنین مقاله معرفی QuerySet پایه ها را مرور می کند.