[{"data":1,"prerenderedAt":8126},["ShallowReactive",2],{"navigation":3,"/models-and-databases/filtering-ordering-slicing":1016,"/models-and-databases/filtering-ordering-slicing-surround":8121},[4,54,89,123,165,211,253,331,389,439,462,488,514,540,578,624,650,672,702,736,774,800,850,856,862,868,874,928],{"title":5,"path":6,"stem":7,"children":8},"Introduction and Foundations","/introduction-and-foundations","01.introduction-and-foundations/01.index",[9,10,14,18,22,26,30,34,38,42,46,50],{"title":5,"path":6,"stem":7},{"title":11,"path":12,"stem":13},"What is Django","/introduction-and-foundations/what-is-django","01.introduction-and-foundations/02.what-is-django",{"title":15,"path":16,"stem":17},"Key Concepts and Philosophy","/introduction-and-foundations/key-concepts-and-philosophy","01.introduction-and-foundations/03.key-concepts-and-philosophy",{"title":19,"path":20,"stem":21},"MVC vs MVT: Understanding Django's Architecture","/introduction-and-foundations/mvc-vs-mvt","01.introduction-and-foundations/04.mvc-vs-mvt",{"title":23,"path":24,"stem":25},"Project Structure Overview","/introduction-and-foundations/project-structure-overview","01.introduction-and-foundations/05.project-structure-overview",{"title":27,"path":28,"stem":29},"Installing Django","/introduction-and-foundations/installing-django","01.introduction-and-foundations/06.installing-django",{"title":31,"path":32,"stem":33},"Creating Your First Django Project","/introduction-and-foundations/creating-first-project","01.introduction-and-foundations/07.creating-first-project",{"title":35,"path":36,"stem":37},"Creating Your First Django App","/introduction-and-foundations/creating-first-app","01.introduction-and-foundations/08.creating-first-app",{"title":39,"path":40,"stem":41},"Your First Django \"Hello World\"","/introduction-and-foundations/hello-world","01.introduction-and-foundations/09.hello-world",{"title":43,"path":44,"stem":45},"Django Quick Start Guide","/introduction-and-foundations/quick-start-guide","01.introduction-and-foundations/10.quick-start-guide",{"title":47,"path":48,"stem":49},"How Django Handles Requests","/introduction-and-foundations/how-django-handles-requests","01.introduction-and-foundations/11.how-django-handles-requests",{"title":51,"path":52,"stem":53},"Django Settings","/introduction-and-foundations/django-settings","01.introduction-and-foundations/12.django-settings",{"title":55,"path":56,"stem":57,"children":58},"The Development Environment","/development-environment","02.development-environment/1.index",[59,61,65,69,73,77,81,85],{"title":60,"path":56,"stem":57},"Development Environment",{"title":62,"path":63,"stem":64},"Recommended Tooling for Django Development","/development-environment/recommended-tooling","02.development-environment/2.recommended-tooling",{"title":66,"path":67,"stem":68},"Virtual Environments","/development-environment/virtual-environments","02.development-environment/3.virtual-environments",{"title":70,"path":71,"stem":72},"Django Admin and Management Commands","/development-environment/admin-and-management-commands","02.development-environment/4.admin-and-management-commands",{"title":74,"path":75,"stem":76},"Django Project Settings","/development-environment/project-settings","02.development-environment/5.project-settings",{"title":78,"path":79,"stem":80},"Managing Django Environments: Local, Staging, and Production","/development-environment/environments-local-staging-production","02.development-environment/6.environments-local-staging-production",{"title":82,"path":83,"stem":84},"Running Django Development Server","/development-environment/running-development-server","02.development-environment/7.running-development-server",{"title":86,"path":87,"stem":88},"Working with Django Shell","/development-environment/working-with-shell","02.development-environment/8.working-with-shell",{"title":90,"path":91,"stem":92,"children":93},"Templates and Presentation Layer","/templates-and-presentation","03.templates-and-presentation/1.index",[94,95,99,103,107,111,115,119],{"title":90,"path":91,"stem":92},{"title":96,"path":97,"stem":98},"Introduction to Django Templates","/templates-and-presentation/introduction-to-templates","03.templates-and-presentation/2.introduction-to-templates",{"title":100,"path":101,"stem":102},"The Django Template Language","/templates-and-presentation/django-template-language","03.templates-and-presentation/3.django-template-language",{"title":104,"path":105,"stem":106},"Template Inheritance","/templates-and-presentation/template-inheritance","03.templates-and-presentation/4.template-inheritance",{"title":108,"path":109,"stem":110},"Built-in Template Tags and Filters","/templates-and-presentation/built-in-template-tags-and-filters","03.templates-and-presentation/5.built-in-template-tags-and-filters",{"title":112,"path":113,"stem":114},"Including Static Files","/templates-and-presentation/including-static-files","03.templates-and-presentation/6.including-static-files",{"title":116,"path":117,"stem":118},"Working with Media Files","/templates-and-presentation/working-with-media-files","03.templates-and-presentation/7.working-with-media-files",{"title":120,"path":121,"stem":122},"Using Alternative Template Engines","/templates-and-presentation/using-alternative-template-engines","03.templates-and-presentation/8.using-alternative-template-engines",{"title":124,"path":125,"stem":126,"children":127},"URLs and Views","/urls-and-views","04.urls-and-views/01.index",[128,129,133,137,141,145,149,153,157,161],{"title":124,"path":125,"stem":126},{"title":130,"path":131,"stem":132},"The URL Dispatcher","/urls-and-views/the-url-dispatcher","04.urls-and-views/02.the-url-dispatcher",{"title":134,"path":135,"stem":136},"Writing Function-Based Views","/urls-and-views/writing-function-based-views","04.urls-and-views/03.writing-function-based-views",{"title":138,"path":139,"stem":140},"View Decorators","/urls-and-views/view-decorators","04.urls-and-views/04.view-decorators",{"title":142,"path":143,"stem":144},"Rendering Responses","/urls-and-views/rendering-responses","04.urls-and-views/05.rendering-responses",{"title":146,"path":147,"stem":148},"Redirects","/urls-and-views/redirects","04.urls-and-views/06.redirects",{"title":150,"path":151,"stem":152},"Handling HTTP Methods","/urls-and-views/handling-http-methods","04.urls-and-views/07.handling-http-methods",{"title":154,"path":155,"stem":156},"Conditional View Processing","/urls-and-views/conditional-view-processing","04.urls-and-views/08.conditional-view-processing",{"title":158,"path":159,"stem":160},"File Uploads","/urls-and-views/file-uploads","04.urls-and-views/09.file-uploads",{"title":162,"path":163,"stem":164},"Using Django Shortcut Functions","/urls-and-views/using-django-shortcut-functions","04.urls-and-views/10.using-django-shortcut-functions",{"title":166,"path":167,"stem":168,"children":169},"Class Based Views","/class-based-views","05.class-based-views/01.index",[170,171,175,179,183,187,191,195,199,203,207],{"title":166,"path":167,"stem":168},{"title":172,"path":173,"stem":174},"Introduction to Class-Based Views","/class-based-views/introduction-to-class-based-views","05.class-based-views/02.introduction-to-class-based-views",{"title":176,"path":177,"stem":178},"Common Base Classes","/class-based-views/common-base-classes","05.class-based-views/03.common-base-classes",{"title":180,"path":181,"stem":182},"Built-in Generic Views","/class-based-views/built-in-generic-views","05.class-based-views/04.built-in-generic-views",{"title":184,"path":185,"stem":186},"Views for CRUD Operations","/class-based-views/views-for-crud-operations","05.class-based-views/05.views-for-crud-operations",{"title":188,"path":189,"stem":190},"Handling Forms with Class-Based Views","/class-based-views/handling-forms-with-class-based-views","05.class-based-views/06.handling-forms-with-class-based-views",{"title":192,"path":193,"stem":194},"Using Mixins","/class-based-views/using-mixins","05.class-based-views/07.using-mixins",{"title":196,"path":197,"stem":198},"URL Configuration with Class-Based Views","/class-based-views/url-configuration-with-class-based-views","05.class-based-views/08.url-configuration-with-class-based-views",{"title":200,"path":201,"stem":202},"Subclassing Generic Views","/class-based-views/subclassing-generic-views","05.class-based-views/09.subclassing-generic-views",{"title":204,"path":205,"stem":206},"Asynchronous Class-Based Views","/class-based-views/asynchronous-class-based-views","05.class-based-views/10.asynchronous-class-based-views",{"title":208,"path":209,"stem":210},"Pagination","/class-based-views/pagination","05.class-based-views/11.pagination",{"title":212,"path":213,"stem":214,"children":215},"Forms and User Input","/forms-and-user-input","06.forms-and-user-input/01.index",[216,217,221,225,229,233,237,241,245,249],{"title":212,"path":213,"stem":214},{"title":218,"path":219,"stem":220},"Understanding HTML Forms","/forms-and-user-input/understanding-html-forms","06.forms-and-user-input/02.understanding-html-forms",{"title":222,"path":223,"stem":224},"Django's Role in Form Handling","/forms-and-user-input/djangos-role-in-form-handling","06.forms-and-user-input/03.djangos-role-in-form-handling",{"title":226,"path":227,"stem":228},"Creating Forms with Forms API","/forms-and-user-input/creating-forms-with-forms-api","06.forms-and-user-input/04.creating-forms-with-forms-api",{"title":230,"path":231,"stem":232},"Form Validation","/forms-and-user-input/form-validation","06.forms-and-user-input/05.form-validation",{"title":234,"path":235,"stem":236},"Built-in Fields and Widgets","/forms-and-user-input/built-in-fields-and-widgets","06.forms-and-user-input/06.built-in-fields-and-widgets",{"title":238,"path":239,"stem":240},"Form Rendering in Templates","/forms-and-user-input/form-rendering-in-templates","06.forms-and-user-input/07.form-rendering-in-templates",{"title":242,"path":243,"stem":244},"Model Forms","/forms-and-user-input/model-forms","06.forms-and-user-input/08.model-forms",{"title":246,"path":247,"stem":248},"Advanced Form Techniques","/forms-and-user-input/advanced-form-techniques","06.forms-and-user-input/09.advanced-form-techniques",{"title":250,"path":251,"stem":252},"Security Considerations for Forms","/forms-and-user-input/security-considerations-for-forms","06.forms-and-user-input/10.security-considerations-for-forms",{"title":254,"path":255,"stem":256,"children":257},"Models and Databases","/models-and-databases","07.models-and-databases/01.index",[258,259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327],{"title":254,"path":255,"stem":256},{"title":260,"path":261,"stem":262},"Understanding Django Models","/models-and-databases/understanding-django-models","07.models-and-databases/02.understanding-django-models",{"title":264,"path":265,"stem":266},"Defining Fields","/models-and-databases/defining-fields","07.models-and-databases/03.defining-fields",{"title":268,"path":269,"stem":270},"Relationships and Foreign Keys","/models-and-databases/relationships-and-foreign-keys","07.models-and-databases/04.relationships-and-foreign-keys",{"title":272,"path":273,"stem":274},"Examples of Relationship Patterns","/models-and-databases/examples-of-relationship-patterns","07.models-and-databases/05.examples-of-relationship-patterns",{"title":276,"path":277,"stem":278},"Making Queries","/models-and-databases/making-queries","07.models-and-databases/06.making-queries",{"title":280,"path":281,"stem":282},"Filtering, Ordering, and Slicing","/models-and-databases/filtering-ordering-slicing","07.models-and-databases/07.filtering-ordering-slicing",{"title":284,"path":285,"stem":286},"Managers and QuerySets","/models-and-databases/managers-and-querysets","07.models-and-databases/08.managers-and-querysets",{"title":288,"path":289,"stem":290},"Aggregation","/models-and-databases/aggregation","07.models-and-databases/09.aggregation",{"title":292,"path":293,"stem":294},"Search","/models-and-databases/search","07.models-and-databases/10.search",{"title":296,"path":297,"stem":298},"Raw SQL Queries","/models-and-databases/raw-sql-queries","07.models-and-databases/11.raw-sql-queries",{"title":300,"path":301,"stem":302},"Transactions","/models-and-databases/transactions","07.models-and-databases/12.transactions",{"title":304,"path":305,"stem":306},"Multiple Databases","/models-and-databases/multiple-databases","07.models-and-databases/13.multiple-databases",{"title":308,"path":309,"stem":310},"Tablespaces","/models-and-databases/tablespaces","07.models-and-databases/14.tablespaces",{"title":312,"path":313,"stem":314},"Composite Primary Keys","/models-and-databases/composite-primary-keys","07.models-and-databases/15.composite-primary-keys",{"title":316,"path":317,"stem":318},"Database Instrumentation","/models-and-databases/database-instrumentation","07.models-and-databases/16.database-instrumentation",{"title":320,"path":321,"stem":322},"Database Optimization","/models-and-databases/database-optimization","07.models-and-databases/17.database-optimization",{"title":324,"path":325,"stem":326},"Fixtures","/models-and-databases/fixtures","07.models-and-databases/18.fixtures",{"title":328,"path":329,"stem":330},"Signals","/models-and-databases/signals","07.models-and-databases/19.signals",{"title":332,"path":333,"stem":334,"children":335},"Migrations","/migrations","08.migrations/01.index",[336,337,341,345,349,353,357,361,365,369,373,377,381,385],{"title":332,"path":333,"stem":334},{"title":338,"path":339,"stem":340},"How Migrations Work","/migrations/how-migrations-work","08.migrations/02.how-migrations-work",{"title":342,"path":343,"stem":344},"Management Commands","/migrations/management-commands","08.migrations/03.management-commands",{"title":346,"path":347,"stem":348},"Dependencies and Workflow","/migrations/dependencies-and-workflow","08.migrations/04.dependencies-and-workflow",{"title":350,"path":351,"stem":352},"Transaction Handling","/migrations/transaction-handling","08.migrations/05.transaction-handling",{"title":354,"path":355,"stem":356},"Adding Migrations to Apps","/migrations/adding-migrations-to-apps","08.migrations/06.adding-migrations-to-apps",{"title":358,"path":359,"stem":360},"Reversing Migrations","/migrations/reversing-migrations","08.migrations/07.reversing-migrations",{"title":362,"path":363,"stem":364},"Historical Models","/migrations/historical-models","08.migrations/08.historical-models",{"title":366,"path":367,"stem":368},"Considerations When Removing Fields","/migrations/considerations-when-removing-fields","08.migrations/09.considerations-when-removing-fields",{"title":370,"path":371,"stem":372},"Data Migrations","/migrations/data-migrations","08.migrations/10.data-migrations",{"title":374,"path":375,"stem":376},"Squashing Migrations","/migrations/squashing-migrations","08.migrations/11.squashing-migrations",{"title":378,"path":379,"stem":380},"Serializing Values","/migrations/serializing-values","08.migrations/12.serializing-values",{"title":382,"path":383,"stem":384},"Supporting Multiple Django Versions","/migrations/supporting-multiple-django-versions","08.migrations/13.supporting-multiple-django-versions",{"title":386,"path":387,"stem":388},"Django Serialization Framework","/migrations/django-serialization-framework","08.migrations/14.django-serialization-framework",{"title":390,"path":391,"stem":392,"children":393},"Authentication and Authorization","/authentication-and-authorization","09.authentication-and-authorization/01.index",[394,395,399,403,407,411,415,419,423,427,431,435],{"title":390,"path":391,"stem":392},{"title":396,"path":397,"stem":398},"Overview of Django's Authentication System","/authentication-and-authorization/overview-of-django-authentication-system","09.authentication-and-authorization/02.overview-of-django-authentication-system",{"title":400,"path":401,"stem":402},"Users and Groups","/authentication-and-authorization/users-and-groups","09.authentication-and-authorization/03.users-and-groups",{"title":404,"path":405,"stem":406},"Permissions","/authentication-and-authorization/permissions","09.authentication-and-authorization/04.permissions",{"title":408,"path":409,"stem":410},"Password Management","/authentication-and-authorization/password-management","09.authentication-and-authorization/05.password-management",{"title":412,"path":413,"stem":414},"Authentication Views","/authentication-and-authorization/authentication-views","09.authentication-and-authorization/06.authentication-views",{"title":416,"path":417,"stem":418},"Login and Logout","/authentication-and-authorization/login-and-logout","09.authentication-and-authorization/07.login-and-logout",{"title":420,"path":421,"stem":422},"Custom User Models","/authentication-and-authorization/custom-user-models","09.authentication-and-authorization/08.custom-user-models",{"title":424,"path":425,"stem":426},"Middleware for Authentication","/authentication-and-authorization/middleware-for-authentication","09.authentication-and-authorization/09.middleware-for-authentication",{"title":428,"path":429,"stem":430},"Authorization in Views and Templates","/authentication-and-authorization/authorization-in-views-and-templates","09.authentication-and-authorization/10.authorization-in-views-and-templates",{"title":432,"path":433,"stem":434},"Integrating Social Authentication","/authentication-and-authorization/integrating-social-authentication","09.authentication-and-authorization/11.integrating-social-authentication",{"title":436,"path":437,"stem":438},"Security Best Practices","/authentication-and-authorization/security-best-practices","09.authentication-and-authorization/12.security-best-practices",{"title":440,"path":441,"stem":442,"children":443},"Sessions, Cookies, and State","/sessions-cookies-state","10.sessions-cookies-state/01.index",[444,446,450,454,458],{"title":445,"path":441,"stem":442},"Sessions, Cookies, and State Management",{"title":447,"path":448,"stem":449},"Introduction to Sessions","/sessions-cookies-state/introduction-to-sessions","10.sessions-cookies-state/02.introduction-to-sessions",{"title":451,"path":452,"stem":453},"Working with Cookies","/sessions-cookies-state/working-with-cookies","10.sessions-cookies-state/03.working-with-cookies",{"title":455,"path":456,"stem":457},"Server-Side Session Storage Options","/sessions-cookies-state/server-side-session-storage-options","10.sessions-cookies-state/04.server-side-session-storage-options",{"title":459,"path":460,"stem":461},"Session Security","/sessions-cookies-state/session-security","10.sessions-cookies-state/05.session-security",{"title":463,"path":464,"stem":465,"children":466},"Working with Files","/working-with-files","11.working-with-files/01.index",[467,468,472,476,480,484],{"title":463,"path":464,"stem":465},{"title":469,"path":470,"stem":471},"Files in Models","/working-with-files/files-in-models","11.working-with-files/02.files-in-models",{"title":473,"path":474,"stem":475},"The File Object","/working-with-files/the-file-object","11.working-with-files/03.the-file-object",{"title":477,"path":478,"stem":479},"Storage Backends","/working-with-files/storage-backends","11.working-with-files/04.storage-backends",{"title":481,"path":482,"stem":483},"Using Cloud Storage Providers","/working-with-files/using-cloud-storage-providers","11.working-with-files/05.using-cloud-storage-providers",{"title":485,"path":486,"stem":487},"Managing Media in Production","/working-with-files/managing-media-in-production","11.working-with-files/06.managing-media-in-production",{"title":489,"path":490,"stem":491,"children":492},"Admin Site","/admin-site","12.admin-site/01.index",[493,494,498,502,506,510],{"title":489,"path":490,"stem":491},{"title":495,"path":496,"stem":497},"Enabling the Admin","/admin-site/enabling-the-admin","12.admin-site/02.enabling-the-admin",{"title":499,"path":500,"stem":501},"Registering Models","/admin-site/registering-models","12.admin-site/03.registering-models",{"title":503,"path":504,"stem":505},"Customizing Admin Display","/admin-site/customizing-admin-display","12.admin-site/04.customizing-admin-display",{"title":507,"path":508,"stem":509},"Admin Actions","/admin-site/admin-actions","12.admin-site/05.admin-actions",{"title":511,"path":512,"stem":513},"Admin Security Best Practices","/admin-site/admin-security-best-practices","12.admin-site/06.admin-security-best-practices",{"title":515,"path":516,"stem":517,"children":518},"Middleware","/middleware","13.middleware/01.index",[519,520,524,528,532,536],{"title":515,"path":516,"stem":517},{"title":521,"path":522,"stem":523},"Middleware Overview","/middleware/middleware-overview","13.middleware/02.middleware-overview",{"title":525,"path":526,"stem":527},"Built-in Middleware","/middleware/built-in-middleware","13.middleware/03.built-in-middleware",{"title":529,"path":530,"stem":531},"Creating Custom Middleware","/middleware/creating-custom-middleware","13.middleware/04.creating-custom-middleware",{"title":533,"path":534,"stem":535},"Middleware Ordering","/middleware/middleware-ordering","13.middleware/05.middleware-ordering",{"title":537,"path":538,"stem":539},"Performance and Debugging","/middleware/performance-and-debugging","13.middleware/06.performance-and-debugging",{"title":541,"path":542,"stem":543,"children":544},"Security","/security","14.security/01.index",[545,546,550,554,558,562,566,570,574],{"title":541,"path":542,"stem":543},{"title":547,"path":548,"stem":549},"Django Security Philosophy","/security/django-security-philosophy","14.security/02.django-security-philosophy",{"title":551,"path":552,"stem":553},"Cross Site Request Forgery","/security/cross-site-request-forgery","14.security/03.cross-site-request-forgery",{"title":555,"path":556,"stem":557},"Cross Site Scripting","/security/cross-site-scripting","14.security/04.cross-site-scripting",{"title":559,"path":560,"stem":561},"SQL Injection Protection","/security/sql-injection-protection","14.security/05.sql-injection-protection",{"title":563,"path":564,"stem":565},"Clickjacking Protection","/security/clickjacking-protection","14.security/06.clickjacking-protection",{"title":567,"path":568,"stem":569},"HTTPS Setup and HSTS","/security/https-setup-and-hsts","14.security/07.https-setup-and-hsts",{"title":571,"path":572,"stem":573},"Password Storage and Cryptography","/security/password-storage-and-cryptography","14.security/08.password-storage-and-cryptography",{"title":575,"path":576,"stem":577},"Secure Deployment Checklist","/security/secure-deployment-checklist","14.security/09.secure-deployment-checklist",{"title":579,"path":580,"stem":581,"children":582},"Testing","/testing","15.testing/01.index",[583,584,588,592,596,600,604,608,612,616,620],{"title":579,"path":580,"stem":581},{"title":585,"path":586,"stem":587},"Introduction to Django Testing","/testing/introduction-to-django-testing","15.testing/02.introduction-to-django-testing",{"title":589,"path":590,"stem":591},"Writing and Running Tests","/testing/writing-and-running-tests","15.testing/03.writing-and-running-tests",{"title":593,"path":594,"stem":595},"Test Tools","/testing/test-tools","15.testing/04.test-tools",{"title":597,"path":598,"stem":599},"Testing Models","/testing/testing-models","15.testing/05.testing-models",{"title":601,"path":602,"stem":603},"Testing Views","/testing/testing-views","15.testing/06.testing-views",{"title":605,"path":606,"stem":607},"Testing Forms","/testing/testing-forms","15.testing/07.testing-forms",{"title":609,"path":610,"stem":611},"Testing Templates","/testing/testing-templates","15.testing/08.testing-templates",{"title":613,"path":614,"stem":615},"Testing Authentication","/testing/testing-authentication","15.testing/09.testing-authentication",{"title":617,"path":618,"stem":619},"Advanced Testing Topics","/testing/advanced-testing-topics","15.testing/10.advanced-testing-topics",{"title":621,"path":622,"stem":623},"Performance Testing","/testing/performance-testing","15.testing/11.performance-testing",{"title":625,"path":626,"stem":627,"children":628},"Static Assets and Frontend Integration","/static-assets-and-frontend-integration","16.static-assets-and-frontend-integration/01.index",[629,630,634,638,642,646],{"title":625,"path":626,"stem":627},{"title":631,"path":632,"stem":633},"Working with Static Files","/static-assets-and-frontend-integration/working-with-static-files","16.static-assets-and-frontend-integration/02.working-with-static-files",{"title":635,"path":636,"stem":637},"Integrating CSS and JavaScript","/static-assets-and-frontend-integration/integrating-css-and-javascript","16.static-assets-and-frontend-integration/03.integrating-css-and-javascript",{"title":639,"path":640,"stem":641},"Using Build Tools like Vite or Webpack","/static-assets-and-frontend-integration/using-build-tools-like-vite-or-webpack","16.static-assets-and-frontend-integration/04.using-build-tools-like-vite-or-webpack",{"title":643,"path":644,"stem":645},"Using React or Vue with Django","/static-assets-and-frontend-integration/using-react-or-vue-with-django","16.static-assets-and-frontend-integration/05.using-react-or-vue-with-django",{"title":647,"path":648,"stem":649},"Managing CORS","/static-assets-and-frontend-integration/managing-cors","16.static-assets-and-frontend-integration/06.managing-cors",{"title":651,"path":652,"stem":653,"children":654},"Internationalization and Localization","/internationalization-and-localization","17.internationalization-and-localization/01.index",[655,656,660,664,668],{"title":651,"path":652,"stem":653},{"title":657,"path":658,"stem":659},"Enabling Translation","/internationalization-and-localization/enabling-translation","17.internationalization-and-localization/02.enabling-translation",{"title":661,"path":662,"stem":663},"Translating Text in Code and Templates","/internationalization-and-localization/translating-text-in-code-and-templates","17.internationalization-and-localization/03.translating-text-in-code-and-templates",{"title":665,"path":666,"stem":667},"Timezone Support","/internationalization-and-localization/timezone-support","17.internationalization-and-localization/04.timezone-support",{"title":669,"path":670,"stem":671},"Locale Middleware","/internationalization-and-localization/locale-middleware","17.internationalization-and-localization/05.locale-middleware",{"title":673,"path":674,"stem":675,"children":676},"Caching","/caching","18.caching/01.index",[677,678,682,686,690,694,698],{"title":673,"path":674,"stem":675},{"title":679,"path":680,"stem":681},"Introduction to Caching","/caching/introduction-to-caching","18.caching/02.introduction-to-caching",{"title":683,"path":684,"stem":685},"Cache Backends","/caching/cache-backends","18.caching/03.cache-backends",{"title":687,"path":688,"stem":689},"Per View Caching","/caching/per-view-caching","18.caching/04.per-view-caching",{"title":691,"path":692,"stem":693},"Low Level Cache API","/caching/low-level-cache-api","18.caching/05.low-level-cache-api",{"title":695,"path":696,"stem":697},"Template Fragment Caching","/caching/template-fragment-caching","18.caching/06.template-fragment-caching",{"title":699,"path":700,"stem":701},"Deployment Level Caching Patterns","/caching/deployment-level-caching-patterns","18.caching/07.deployment-level-caching-patterns",{"title":703,"path":704,"stem":705,"children":706},"Asynchronous Django","/asynchronous-django","19.asynchronous-django/01.index",[707,708,712,716,720,724,728,732],{"title":703,"path":704,"stem":705},{"title":709,"path":710,"stem":711},"Introduction to ASGI","/asynchronous-django/introduction-to-asgi","19.asynchronous-django/02.introduction-to-asgi",{"title":713,"path":714,"stem":715},"Async Views","/asynchronous-django/async-views","19.asynchronous-django/03.async-views",{"title":717,"path":718,"stem":719},"Async ORM Status","/asynchronous-django/async-orm-status","19.asynchronous-django/04.async-orm-status",{"title":721,"path":722,"stem":723},"WebSockets with Channels","/asynchronous-django/websockets-with-channels","19.asynchronous-django/05.websockets-with-channels",{"title":725,"path":726,"stem":727},"Background Tasks with Celery or RQ","/asynchronous-django/background-tasks-with-celery-or-rq","19.asynchronous-django/06.background-tasks-with-celery-or-rq",{"title":729,"path":730,"stem":731},"Asynchronous Support","/asynchronous-django/asynchronous-support","19.asynchronous-django/07.asynchronous-support",{"title":733,"path":734,"stem":735},"Django's Tasks Framework","/asynchronous-django/django-tasks-framework","19.asynchronous-django/08.django-tasks-framework",{"title":737,"path":738,"stem":739,"children":740},"Deployment","/deployment","20.deployment/01.index",[741,742,746,750,754,758,762,766,770],{"title":737,"path":738,"stem":739},{"title":743,"path":744,"stem":745},"Preparing for Production","/deployment/preparing-for-production","20.deployment/02.preparing-for-production",{"title":747,"path":748,"stem":749},"Using WSGI and ASGI Servers","/deployment/using-wsgi-and-asgi-servers","20.deployment/03.using-wsgi-and-asgi-servers",{"title":751,"path":752,"stem":753},"Deploying on Linux Servers","/deployment/deploying-on-linux-servers","20.deployment/04.deploying-on-linux-servers",{"title":755,"path":756,"stem":757},"Using Docker","/deployment/using-docker","20.deployment/05.using-docker",{"title":759,"path":760,"stem":761},"Cloud Deployment Guides","/deployment/cloud-deployment-guides","20.deployment/06.cloud-deployment-guides",{"title":763,"path":764,"stem":765},"Scaling and Load Balancing","/deployment/scaling-and-load-balancing","20.deployment/07.scaling-and-load-balancing",{"title":767,"path":768,"stem":769},"Monitoring and Logging","/deployment/monitoring-and-logging","20.deployment/08.monitoring-and-logging",{"title":771,"path":772,"stem":773},"Backup Strategies","/deployment/backup-strategies","20.deployment/09.backup-strategies",{"title":775,"path":776,"stem":777,"children":778},"Performance and Optimization","/performance-and-optimization","21.performance-and-optimization/01.index",[779,780,784,788,792,796],{"title":775,"path":776,"stem":777},{"title":781,"path":782,"stem":783},"Query Optimization","/performance-and-optimization/query-optimization","21.performance-and-optimization/02.query-optimization",{"title":785,"path":786,"stem":787},"Template Rendering Optimization","/performance-and-optimization/template-rendering-optimization","21.performance-and-optimization/03.template-rendering-optimization",{"title":789,"path":790,"stem":791},"Using Select Related and Prefetch Related","/performance-and-optimization/using-select-related-and-prefetch-related","21.performance-and-optimization/04.using-select-related-and-prefetch-related",{"title":793,"path":794,"stem":795},"Caching Strategies","/performance-and-optimization/caching-strategies","21.performance-and-optimization/05.caching-strategies",{"title":797,"path":798,"stem":799},"Profiling Django Apps","/performance-and-optimization/profiling-django-apps","21.performance-and-optimization/06.profiling-django-apps",{"title":801,"path":802,"stem":803,"children":804},"Advanced and Expert Topics","/advanced-and-expert-topics","22.advanced-and-expert-topics/01.index",[805,806,810,814,818,822,826,830,834,838,842,846],{"title":801,"path":802,"stem":803},{"title":807,"path":808,"stem":809},"System Architecture Patterns","/advanced-and-expert-topics/system-architecture-patterns","22.advanced-and-expert-topics/02.system-architecture-patterns",{"title":811,"path":812,"stem":813},"Domain Driven Design with Django","/advanced-and-expert-topics/domain-driven-design-with-django","22.advanced-and-expert-topics/03.domain-driven-design-with-django",{"title":815,"path":816,"stem":817},"Building Large Scale Django Projects","/advanced-and-expert-topics/building-large-scale-django-projects","22.advanced-and-expert-topics/04.building-large-scale-django-projects",{"title":819,"path":820,"stem":821},"Plugin Architectures for Django Apps","/advanced-and-expert-topics/plugin-architectures-for-django-apps","22.advanced-and-expert-topics/05.plugin-architectures-for-django-apps",{"title":823,"path":824,"stem":825},"Extending Django's Core","/advanced-and-expert-topics/extending-djangos-core","22.advanced-and-expert-topics/06.extending-djangos-core",{"title":827,"path":828,"stem":829},"Custom ORM Expressions","/advanced-and-expert-topics/custom-orm-expressions","22.advanced-and-expert-topics/07.custom-orm-expressions",{"title":831,"path":832,"stem":833},"Custom Management Commands","/advanced-and-expert-topics/custom-management-commands","22.advanced-and-expert-topics/08.custom-management-commands",{"title":835,"path":836,"stem":837},"Working with Signals","/advanced-and-expert-topics/working-with-signals","22.advanced-and-expert-topics/09.working-with-signals",{"title":839,"path":840,"stem":841},"Building Reusable Django Packages","/advanced-and-expert-topics/building-reusable-django-packages","22.advanced-and-expert-topics/10.building-reusable-django-packages",{"title":843,"path":844,"stem":845},"Integrating Microservices","/advanced-and-expert-topics/integrating-microservices","22.advanced-and-expert-topics/11.integrating-microservices",{"title":847,"path":848,"stem":849},"Advanced Security Hardening","/advanced-and-expert-topics/advanced-security-hardening","22.advanced-and-expert-topics/12.advanced-security-hardening",{"title":851,"path":852,"stem":853,"children":854},"Logging in Django","/logging-in-django","23.logging-in-django/01.index",[855],{"title":851,"path":852,"stem":853},{"title":857,"path":858,"stem":859,"children":860},"FAQ and Troubleshooting","/faq-and-troubleshooting","24.faq-and-troubleshooting/01.index",[861],{"title":857,"path":858,"stem":859},{"title":863,"path":864,"stem":865,"children":866},"External Packages and Ecosystem","/external-packages-and-ecosystem","25.external-packages-and-ecosystem/01.index",[867],{"title":863,"path":864,"stem":865},{"title":869,"path":870,"stem":871,"children":872},"Django Internals and Contributing","/django-internals-and-contributing","26.django-internals-and-contributing/01.index",[873],{"title":869,"path":870,"stem":871},{"title":875,"path":876,"stem":877,"children":878},"Microservices with Django","/microservices-with-django","27.microservices-with-django/01.index",[879,880,884,888,892,896,900,904,908,912,916,920,924],{"title":875,"path":876,"stem":877},{"title":881,"path":882,"stem":883},"What Is a Microservice?","/microservices-with-django/what-is-a-microservice","27.microservices-with-django/02.what-is-a-microservice",{"title":885,"path":886,"stem":887},"Introducing the Django Microservices Architecture","/microservices-with-django/django-microservices-architecture","27.microservices-with-django/03.django-microservices-architecture",{"title":889,"path":890,"stem":891},"Setting Up the Development and Runtime Environment","/microservices-with-django/development-environment","27.microservices-with-django/04.development-environment",{"title":893,"path":894,"stem":895},"Cloud-native Data Processing with MongoDB","/microservices-with-django/cloud-native-data-processing","27.microservices-with-django/05.cloud-native-data-processing",{"title":897,"path":898,"stem":899},"Creating RESTful APIs for Microservices","/microservices-with-django/restful-apis","27.microservices-with-django/06.restful-apis",{"title":901,"path":902,"stem":903},"Orchestrating Microservices with Celery and RabbitMQ","/microservices-with-django/orchestrating-celery-rabbitmq","27.microservices-with-django/07.orchestrating-celery-rabbitmq",{"title":905,"path":906,"stem":907},"Testing Microservices","/microservices-with-django/testing-microservices","27.microservices-with-django/08.testing-microservices",{"title":909,"path":910,"stem":911},"Deploying Microservices","/microservices-with-django/deploying-microservices","27.microservices-with-django/09.deploying-microservices",{"title":913,"path":914,"stem":915},"Securing Microservices","/microservices-with-django/securing-microservices","27.microservices-with-django/10.securing-microservices",{"title":917,"path":918,"stem":919},"Improving Microservices Performance with Caching","/microservices-with-django/performance-caching","27.microservices-with-django/11.performance-caching",{"title":921,"path":922,"stem":923},"Best Practices","/microservices-with-django/best-practices","27.microservices-with-django/12.best-practices",{"title":925,"path":926,"stem":927},"Transforming a Monolithic Web App into a Microservice version","/microservices-with-django/monolith-to-microservices","27.microservices-with-django/13.monolith-to-microservices",{"title":929,"path":930,"stem":931,"children":932},"Releases","/releases","releases",[933,936,940,944,948,952,956,960,964,968,972,976,980,984,988,992,996,1000,1004,1008,1012],{"title":934,"path":930,"stem":935},"Django Releases","releases/index",{"title":937,"path":938,"stem":939},"Django 5.1.10 release notes","/releases/5.1.10","releases/5.1.10",{"title":941,"path":942,"stem":943},"Django 5.1.11 release notes","/releases/5.1.11","releases/5.1.11",{"title":945,"path":946,"stem":947},"Django 5.1.12 release notes","/releases/5.1.12","releases/5.1.12",{"title":949,"path":950,"stem":951},"Django 5.1.13 release notes","/releases/5.1.13","releases/5.1.13",{"title":953,"path":954,"stem":955},"Django 5.1.14 release notes","/releases/5.1.14","releases/5.1.14",{"title":957,"path":958,"stem":959},"Django 5.1.15 release notes","/releases/5.1.15","releases/5.1.15",{"title":961,"path":962,"stem":963},"Django 5.2 release notes","/releases/5.2","releases/5.2",{"title":965,"path":966,"stem":967},"Django 5.2.1 release notes","/releases/5.2.1","releases/5.2.1",{"title":969,"path":970,"stem":971},"Django 5.2.10 release notes","/releases/5.2.10","releases/5.2.10",{"title":973,"path":974,"stem":975},"Django 5.2.2 release notes","/releases/5.2.2","releases/5.2.2",{"title":977,"path":978,"stem":979},"Django 5.2.3 release notes","/releases/5.2.3","releases/5.2.3",{"title":981,"path":982,"stem":983},"Django 5.2.4 release notes","/releases/5.2.4","releases/5.2.4",{"title":985,"path":986,"stem":987},"Django 5.2.5 release notes","/releases/5.2.5","releases/5.2.5",{"title":989,"path":990,"stem":991},"Django 5.2.6 release notes","/releases/5.2.6","releases/5.2.6",{"title":993,"path":994,"stem":995},"Django 5.2.7 release notes","/releases/5.2.7","releases/5.2.7",{"title":997,"path":998,"stem":999},"Django 5.2.8 release notes","/releases/5.2.8","releases/5.2.8",{"title":1001,"path":1002,"stem":1003},"Django 5.2.9 release notes","/releases/5.2.9","releases/5.2.9",{"title":1005,"path":1006,"stem":1007},"Django 6.0 release notes","/releases/6.0","releases/6.0",{"title":1009,"path":1010,"stem":1011},"Django 6.0.1 release notes","/releases/6.0.1","releases/6.0.1",{"title":1013,"path":1014,"stem":1015},"Django 6.1 release notes - UNDER DEVELOPMENT","/releases/6.1","releases/6.1",{"id":1017,"title":280,"body":1018,"description":1028,"extension":8116,"links":8117,"meta":8118,"navigation":1121,"path":281,"seo":8119,"stem":282,"__hash__":8120},"docs/07.models-and-databases/07.filtering-ordering-slicing.md",{"type":1019,"value":1020,"toc":8098},"minimark",[1021,1025,1029,1034,1039,1792,1796,3262,3266,3845,3849,3853,4134,4138,4899,4903,5587,5591,5595,5861,5865,7027,7031,7857,7861,8091,8094],[1022,1023,280],"h1",{"id":1024},"filtering-ordering-and-slicing",[1026,1027,1028],"p",{},"Django's QuerySet API provides powerful tools for filtering, ordering, and slicing data. Mastering these techniques is essential for building efficient database queries and creating responsive applications.",[1030,1031,1033],"h2",{"id":1032},"advanced-filtering-techniques","Advanced Filtering Techniques",[1035,1036,1038],"h3",{"id":1037},"complex-filter-combinations","Complex Filter Combinations",[1040,1041,1046],"pre",{"className":1042,"code":1043,"language":1044,"meta":1045,"style":1045},"language-python shiki shiki-themes material-theme-lighter vitesse-light vitesse-dark","from django.db.models import Q, F\nfrom django.utils import timezone\nfrom datetime import timedelta\n\n# Multiple filter conditions (AND by default)\nposts = Post.objects.filter(\n    status='published',\n    author__is_active=True,\n    created_at__gte=timezone.now() - timedelta(days=30)\n)\n\n# Chaining filters (equivalent to above)\nposts = Post.objects.filter(status='published') \\\n                   .filter(author__is_active=True) \\\n                   .filter(created_at__gte=timezone.now() - timedelta(days=30))\n\n# Exclude conditions\nposts = Post.objects.exclude(status='draft') \\\n                   .exclude(author__email__endswith='@spam.com')\n\n# Combining filter and exclude\nposts = Post.objects.filter(status='published') \\\n                   .exclude(tags__name='deprecated')\n\n# Complex Q object combinations\nsearch_query = Q(title__icontains='django') | Q(content__icontains='django')\ncategory_filter = Q(category__slug='programming') | Q(category__slug='web-dev')\ndate_filter = Q(created_at__gte=timezone.now() - timedelta(days=90))\n\nposts = Post.objects.filter(search_query & category_filter & date_filter)\n\n# Nested Q objects\nposts = Post.objects.filter(\n    Q(status='published') & \n    (Q(author__name__icontains='john') | Q(author__email__icontains='john')) &\n    ~Q(tags__name='archived')\n)\n","python","",[1047,1048,1049,1086,1103,1116,1123,1130,1157,1179,1193,1234,1239,1244,1250,1286,1307,1344,1349,1355,1390,1413,1418,1424,1457,1480,1485,1491,1537,1582,1621,1626,1660,1665,1671,1690,1716,1764,1787],"code",{"__ignoreMap":1045},[1050,1051,1054,1058,1062,1066,1069,1071,1074,1077,1080,1083],"span",{"class":1052,"line":1053},"line",1,[1050,1055,1057],{"class":1056},"siDh9","from",[1050,1059,1061],{"class":1060},"sftqT"," django",[1050,1063,1065],{"class":1064},"soVBu",".",[1050,1067,1068],{"class":1060},"db",[1050,1070,1065],{"class":1064},[1050,1072,1073],{"class":1060},"models ",[1050,1075,1076],{"class":1056},"import",[1050,1078,1079],{"class":1060}," Q",[1050,1081,1082],{"class":1064},",",[1050,1084,1085],{"class":1060}," F\n",[1050,1087,1089,1091,1093,1095,1098,1100],{"class":1052,"line":1088},2,[1050,1090,1057],{"class":1056},[1050,1092,1061],{"class":1060},[1050,1094,1065],{"class":1064},[1050,1096,1097],{"class":1060},"utils ",[1050,1099,1076],{"class":1056},[1050,1101,1102],{"class":1060}," timezone\n",[1050,1104,1106,1108,1111,1113],{"class":1052,"line":1105},3,[1050,1107,1057],{"class":1056},[1050,1109,1110],{"class":1060}," datetime ",[1050,1112,1076],{"class":1056},[1050,1114,1115],{"class":1060}," timedelta\n",[1050,1117,1119],{"class":1052,"line":1118},4,[1050,1120,1122],{"emptyLinePlaceholder":1121},true,"\n",[1050,1124,1126],{"class":1052,"line":1125},5,[1050,1127,1129],{"class":1128},"s9Tkl","# Multiple filter conditions (AND by default)\n",[1050,1131,1133,1136,1139,1142,1144,1148,1150,1154],{"class":1052,"line":1132},6,[1050,1134,1135],{"class":1060},"posts ",[1050,1137,1138],{"class":1064},"=",[1050,1140,1141],{"class":1060}," Post",[1050,1143,1065],{"class":1064},[1050,1145,1147],{"class":1146},"sBPpx","objects",[1050,1149,1065],{"class":1064},[1050,1151,1153],{"class":1152},"siWMO","filter",[1050,1155,1156],{"class":1064},"(\n",[1050,1158,1160,1164,1166,1170,1174,1176],{"class":1052,"line":1159},7,[1050,1161,1163],{"class":1162},"sqOPj","    status",[1050,1165,1138],{"class":1064},[1050,1167,1169],{"class":1168},"sbYkP","'",[1050,1171,1173],{"class":1172},"sTbE_","published",[1050,1175,1169],{"class":1168},[1050,1177,1178],{"class":1064},",\n",[1050,1180,1182,1185,1187,1191],{"class":1052,"line":1181},8,[1050,1183,1184],{"class":1162},"    author__is_active",[1050,1186,1138],{"class":1064},[1050,1188,1190],{"class":1189},"s8XtY","True",[1050,1192,1178],{"class":1064},[1050,1194,1196,1199,1201,1204,1206,1209,1212,1216,1219,1222,1225,1227,1231],{"class":1052,"line":1195},9,[1050,1197,1198],{"class":1162},"    created_at__gte",[1050,1200,1138],{"class":1064},[1050,1202,1203],{"class":1152},"timezone",[1050,1205,1065],{"class":1064},[1050,1207,1208],{"class":1152},"now",[1050,1210,1211],{"class":1064},"()",[1050,1213,1215],{"class":1214},"sVsLi"," -",[1050,1217,1218],{"class":1152}," timedelta",[1050,1220,1221],{"class":1064},"(",[1050,1223,1224],{"class":1162},"days",[1050,1226,1138],{"class":1064},[1050,1228,1230],{"class":1229},"s7CZa","30",[1050,1232,1233],{"class":1064},")\n",[1050,1235,1237],{"class":1052,"line":1236},10,[1050,1238,1233],{"class":1064},[1050,1240,1242],{"class":1052,"line":1241},11,[1050,1243,1122],{"emptyLinePlaceholder":1121},[1050,1245,1247],{"class":1052,"line":1246},12,[1050,1248,1249],{"class":1128},"# Chaining filters (equivalent to above)\n",[1050,1251,1253,1255,1257,1259,1261,1263,1265,1267,1269,1272,1274,1276,1278,1280,1283],{"class":1052,"line":1252},13,[1050,1254,1135],{"class":1060},[1050,1256,1138],{"class":1064},[1050,1258,1141],{"class":1060},[1050,1260,1065],{"class":1064},[1050,1262,1147],{"class":1146},[1050,1264,1065],{"class":1064},[1050,1266,1153],{"class":1152},[1050,1268,1221],{"class":1064},[1050,1270,1271],{"class":1162},"status",[1050,1273,1138],{"class":1064},[1050,1275,1169],{"class":1168},[1050,1277,1173],{"class":1172},[1050,1279,1169],{"class":1168},[1050,1281,1282],{"class":1064},")",[1050,1284,1285],{"class":1064}," \\\n",[1050,1287,1289,1292,1294,1296,1299,1301,1303,1305],{"class":1052,"line":1288},14,[1050,1290,1291],{"class":1064},"                   .",[1050,1293,1153],{"class":1152},[1050,1295,1221],{"class":1064},[1050,1297,1298],{"class":1162},"author__is_active",[1050,1300,1138],{"class":1064},[1050,1302,1190],{"class":1189},[1050,1304,1282],{"class":1064},[1050,1306,1285],{"class":1064},[1050,1308,1310,1312,1314,1316,1319,1321,1323,1325,1327,1329,1331,1333,1335,1337,1339,1341],{"class":1052,"line":1309},15,[1050,1311,1291],{"class":1064},[1050,1313,1153],{"class":1152},[1050,1315,1221],{"class":1064},[1050,1317,1318],{"class":1162},"created_at__gte",[1050,1320,1138],{"class":1064},[1050,1322,1203],{"class":1152},[1050,1324,1065],{"class":1064},[1050,1326,1208],{"class":1152},[1050,1328,1211],{"class":1064},[1050,1330,1215],{"class":1214},[1050,1332,1218],{"class":1152},[1050,1334,1221],{"class":1064},[1050,1336,1224],{"class":1162},[1050,1338,1138],{"class":1064},[1050,1340,1230],{"class":1229},[1050,1342,1343],{"class":1064},"))\n",[1050,1345,1347],{"class":1052,"line":1346},16,[1050,1348,1122],{"emptyLinePlaceholder":1121},[1050,1350,1352],{"class":1052,"line":1351},17,[1050,1353,1354],{"class":1128},"# Exclude conditions\n",[1050,1356,1358,1360,1362,1364,1366,1368,1370,1373,1375,1377,1379,1381,1384,1386,1388],{"class":1052,"line":1357},18,[1050,1359,1135],{"class":1060},[1050,1361,1138],{"class":1064},[1050,1363,1141],{"class":1060},[1050,1365,1065],{"class":1064},[1050,1367,1147],{"class":1146},[1050,1369,1065],{"class":1064},[1050,1371,1372],{"class":1152},"exclude",[1050,1374,1221],{"class":1064},[1050,1376,1271],{"class":1162},[1050,1378,1138],{"class":1064},[1050,1380,1169],{"class":1168},[1050,1382,1383],{"class":1172},"draft",[1050,1385,1169],{"class":1168},[1050,1387,1282],{"class":1064},[1050,1389,1285],{"class":1064},[1050,1391,1393,1395,1397,1399,1402,1404,1406,1409,1411],{"class":1052,"line":1392},19,[1050,1394,1291],{"class":1064},[1050,1396,1372],{"class":1152},[1050,1398,1221],{"class":1064},[1050,1400,1401],{"class":1162},"author__email__endswith",[1050,1403,1138],{"class":1064},[1050,1405,1169],{"class":1168},[1050,1407,1408],{"class":1172},"@spam.com",[1050,1410,1169],{"class":1168},[1050,1412,1233],{"class":1064},[1050,1414,1416],{"class":1052,"line":1415},20,[1050,1417,1122],{"emptyLinePlaceholder":1121},[1050,1419,1421],{"class":1052,"line":1420},21,[1050,1422,1423],{"class":1128},"# Combining filter and exclude\n",[1050,1425,1427,1429,1431,1433,1435,1437,1439,1441,1443,1445,1447,1449,1451,1453,1455],{"class":1052,"line":1426},22,[1050,1428,1135],{"class":1060},[1050,1430,1138],{"class":1064},[1050,1432,1141],{"class":1060},[1050,1434,1065],{"class":1064},[1050,1436,1147],{"class":1146},[1050,1438,1065],{"class":1064},[1050,1440,1153],{"class":1152},[1050,1442,1221],{"class":1064},[1050,1444,1271],{"class":1162},[1050,1446,1138],{"class":1064},[1050,1448,1169],{"class":1168},[1050,1450,1173],{"class":1172},[1050,1452,1169],{"class":1168},[1050,1454,1282],{"class":1064},[1050,1456,1285],{"class":1064},[1050,1458,1460,1462,1464,1466,1469,1471,1473,1476,1478],{"class":1052,"line":1459},23,[1050,1461,1291],{"class":1064},[1050,1463,1372],{"class":1152},[1050,1465,1221],{"class":1064},[1050,1467,1468],{"class":1162},"tags__name",[1050,1470,1138],{"class":1064},[1050,1472,1169],{"class":1168},[1050,1474,1475],{"class":1172},"deprecated",[1050,1477,1169],{"class":1168},[1050,1479,1233],{"class":1064},[1050,1481,1483],{"class":1052,"line":1482},24,[1050,1484,1122],{"emptyLinePlaceholder":1121},[1050,1486,1488],{"class":1052,"line":1487},25,[1050,1489,1490],{"class":1128},"# Complex Q object combinations\n",[1050,1492,1494,1497,1499,1501,1503,1506,1508,1510,1513,1515,1517,1520,1522,1524,1527,1529,1531,1533,1535],{"class":1052,"line":1493},26,[1050,1495,1496],{"class":1060},"search_query ",[1050,1498,1138],{"class":1064},[1050,1500,1079],{"class":1152},[1050,1502,1221],{"class":1064},[1050,1504,1505],{"class":1162},"title__icontains",[1050,1507,1138],{"class":1064},[1050,1509,1169],{"class":1168},[1050,1511,1512],{"class":1172},"django",[1050,1514,1169],{"class":1168},[1050,1516,1282],{"class":1064},[1050,1518,1519],{"class":1214}," |",[1050,1521,1079],{"class":1152},[1050,1523,1221],{"class":1064},[1050,1525,1526],{"class":1162},"content__icontains",[1050,1528,1138],{"class":1064},[1050,1530,1169],{"class":1168},[1050,1532,1512],{"class":1172},[1050,1534,1169],{"class":1168},[1050,1536,1233],{"class":1064},[1050,1538,1540,1543,1545,1547,1549,1552,1554,1556,1559,1561,1563,1565,1567,1569,1571,1573,1575,1578,1580],{"class":1052,"line":1539},27,[1050,1541,1542],{"class":1060},"category_filter ",[1050,1544,1138],{"class":1064},[1050,1546,1079],{"class":1152},[1050,1548,1221],{"class":1064},[1050,1550,1551],{"class":1162},"category__slug",[1050,1553,1138],{"class":1064},[1050,1555,1169],{"class":1168},[1050,1557,1558],{"class":1172},"programming",[1050,1560,1169],{"class":1168},[1050,1562,1282],{"class":1064},[1050,1564,1519],{"class":1214},[1050,1566,1079],{"class":1152},[1050,1568,1221],{"class":1064},[1050,1570,1551],{"class":1162},[1050,1572,1138],{"class":1064},[1050,1574,1169],{"class":1168},[1050,1576,1577],{"class":1172},"web-dev",[1050,1579,1169],{"class":1168},[1050,1581,1233],{"class":1064},[1050,1583,1585,1588,1590,1592,1594,1596,1598,1600,1602,1604,1606,1608,1610,1612,1614,1616,1619],{"class":1052,"line":1584},28,[1050,1586,1587],{"class":1060},"date_filter ",[1050,1589,1138],{"class":1064},[1050,1591,1079],{"class":1152},[1050,1593,1221],{"class":1064},[1050,1595,1318],{"class":1162},[1050,1597,1138],{"class":1064},[1050,1599,1203],{"class":1152},[1050,1601,1065],{"class":1064},[1050,1603,1208],{"class":1152},[1050,1605,1211],{"class":1064},[1050,1607,1215],{"class":1214},[1050,1609,1218],{"class":1152},[1050,1611,1221],{"class":1064},[1050,1613,1224],{"class":1162},[1050,1615,1138],{"class":1064},[1050,1617,1618],{"class":1229},"90",[1050,1620,1343],{"class":1064},[1050,1622,1624],{"class":1052,"line":1623},29,[1050,1625,1122],{"emptyLinePlaceholder":1121},[1050,1627,1629,1631,1633,1635,1637,1639,1641,1643,1645,1647,1650,1653,1655,1658],{"class":1052,"line":1628},30,[1050,1630,1135],{"class":1060},[1050,1632,1138],{"class":1064},[1050,1634,1141],{"class":1060},[1050,1636,1065],{"class":1064},[1050,1638,1147],{"class":1146},[1050,1640,1065],{"class":1064},[1050,1642,1153],{"class":1152},[1050,1644,1221],{"class":1064},[1050,1646,1496],{"class":1152},[1050,1648,1649],{"class":1214},"&",[1050,1651,1652],{"class":1152}," category_filter ",[1050,1654,1649],{"class":1214},[1050,1656,1657],{"class":1152}," date_filter",[1050,1659,1233],{"class":1064},[1050,1661,1663],{"class":1052,"line":1662},31,[1050,1664,1122],{"emptyLinePlaceholder":1121},[1050,1666,1668],{"class":1052,"line":1667},32,[1050,1669,1670],{"class":1128},"# Nested Q objects\n",[1050,1672,1674,1676,1678,1680,1682,1684,1686,1688],{"class":1052,"line":1673},33,[1050,1675,1135],{"class":1060},[1050,1677,1138],{"class":1064},[1050,1679,1141],{"class":1060},[1050,1681,1065],{"class":1064},[1050,1683,1147],{"class":1146},[1050,1685,1065],{"class":1064},[1050,1687,1153],{"class":1152},[1050,1689,1156],{"class":1064},[1050,1691,1693,1696,1698,1700,1702,1704,1706,1708,1710,1713],{"class":1052,"line":1692},34,[1050,1694,1695],{"class":1152},"    Q",[1050,1697,1221],{"class":1064},[1050,1699,1271],{"class":1162},[1050,1701,1138],{"class":1064},[1050,1703,1169],{"class":1168},[1050,1705,1173],{"class":1172},[1050,1707,1169],{"class":1168},[1050,1709,1282],{"class":1064},[1050,1711,1712],{"class":1214}," &",[1050,1714,1715],{"class":1152}," \n",[1050,1717,1719,1722,1725,1727,1730,1732,1734,1737,1739,1741,1743,1745,1747,1750,1752,1754,1756,1758,1761],{"class":1052,"line":1718},35,[1050,1720,1721],{"class":1064},"    (",[1050,1723,1724],{"class":1152},"Q",[1050,1726,1221],{"class":1064},[1050,1728,1729],{"class":1162},"author__name__icontains",[1050,1731,1138],{"class":1064},[1050,1733,1169],{"class":1168},[1050,1735,1736],{"class":1172},"john",[1050,1738,1169],{"class":1168},[1050,1740,1282],{"class":1064},[1050,1742,1519],{"class":1214},[1050,1744,1079],{"class":1152},[1050,1746,1221],{"class":1064},[1050,1748,1749],{"class":1162},"author__email__icontains",[1050,1751,1138],{"class":1064},[1050,1753,1169],{"class":1168},[1050,1755,1736],{"class":1172},[1050,1757,1169],{"class":1168},[1050,1759,1760],{"class":1064},"))",[1050,1762,1763],{"class":1214}," &\n",[1050,1765,1767,1770,1772,1774,1776,1778,1780,1783,1785],{"class":1052,"line":1766},36,[1050,1768,1769],{"class":1214},"    ~",[1050,1771,1724],{"class":1152},[1050,1773,1221],{"class":1064},[1050,1775,1468],{"class":1162},[1050,1777,1138],{"class":1064},[1050,1779,1169],{"class":1168},[1050,1781,1782],{"class":1172},"archived",[1050,1784,1169],{"class":1168},[1050,1786,1233],{"class":1064},[1050,1788,1790],{"class":1052,"line":1789},37,[1050,1791,1233],{"class":1064},[1035,1793,1795],{"id":1794},"field-lookups-deep-dive","Field Lookups Deep Dive",[1040,1797,1799],{"className":1042,"code":1798,"language":1044,"meta":1045,"style":1045},"# Text field lookups\nposts = Post.objects.filter(title__exact='Django Tutorial')\nposts = Post.objects.filter(title__iexact='django tutorial')  # Case-insensitive\nposts = Post.objects.filter(title__contains='Django')\nposts = Post.objects.filter(title__icontains='django')       # Case-insensitive\nposts = Post.objects.filter(title__startswith='How to')\nposts = Post.objects.filter(title__endswith='Tutorial')\nposts = Post.objects.filter(title__istartswith='how to')     # Case-insensitive\nposts = Post.objects.filter(title__iendswith='tutorial')     # Case-insensitive\n\n# Numeric field lookups\nposts = Post.objects.filter(view_count__exact=1000)\nposts = Post.objects.filter(view_count__gt=1000)            # Greater than\nposts = Post.objects.filter(view_count__gte=1000)           # Greater than or equal\nposts = Post.objects.filter(view_count__lt=1000)            # Less than\nposts = Post.objects.filter(view_count__lte=1000)           # Less than or equal\nposts = Post.objects.filter(view_count__range=(100, 1000))  # Between values\n\n# Date and time lookups\nfrom datetime import date, datetime\n\nposts = Post.objects.filter(created_at__year=2023)\nposts = Post.objects.filter(created_at__month=12)\nposts = Post.objects.filter(created_at__day=25)\nposts = Post.objects.filter(created_at__week=52)\nposts = Post.objects.filter(created_at__week_day=1)         # Sunday = 1\nposts = Post.objects.filter(created_at__quarter=4)          # Q4\nposts = Post.objects.filter(created_at__hour=14)\nposts = Post.objects.filter(created_at__minute=30)\nposts = Post.objects.filter(created_at__second=45)\n\n# Date-only comparisons\ntoday = date.today()\nposts = Post.objects.filter(created_at__date=today)\nposts = Post.objects.filter(created_at__date__gte=today)\n\n# Time-only comparisons\nfrom datetime import time\nmorning = time(9, 0)\nposts = Post.objects.filter(created_at__time__gte=morning)\n\n# ISO week date\nposts = Post.objects.filter(created_at__iso_week_day=1)     # Monday = 1\nposts = Post.objects.filter(created_at__iso_year=2023)\n\n# Null and boolean lookups\nposts = Post.objects.filter(published_at__isnull=True)     # Unpublished posts\nposts = Post.objects.filter(published_at__isnull=False)    # Published posts\nposts = Post.objects.filter(is_featured=True)\nposts = Post.objects.filter(is_featured__exact=True)       # Equivalent\n\n# List membership\npost_ids = [1, 2, 3, 4, 5]\nposts = Post.objects.filter(id__in=post_ids)\n\ncategories = ['tech', 'programming', 'web-development']\nposts = Post.objects.filter(category__slug__in=categories)\n\n# Subquery filtering\npopular_authors = Author.objects.filter(posts__view_count__gt=10000)\nposts = Post.objects.filter(author__in=popular_authors)\n\n# Regular expressions (database-dependent)\nposts = Post.objects.filter(title__regex=r'^(How|What|Why)')\nposts = Post.objects.filter(title__iregex=r'^(how|what|why)')  # Case-insensitive\n\n# Full-text search (PostgreSQL)\n# posts = Post.objects.filter(title__search='django tutorial')\n",[1047,1800,1801,1806,1838,1873,1905,1938,1970,2002,2037,2071,2075,2080,2108,2138,2168,2198,2228,2265,2269,2274,2290,2294,2322,2350,2378,2406,2437,2468,2496,2523,2551,2555,2560,2577,2604,2631,2635,2640,2652,2675,2704,2709,2715,2746,2774,2779,2785,2816,2847,2875,2906,2911,2917,2953,2982,2987,3024,3053,3058,3064,3095,3124,3129,3135,3192,3245,3250,3256],{"__ignoreMap":1045},[1050,1802,1803],{"class":1052,"line":1053},[1050,1804,1805],{"class":1128},"# Text field lookups\n",[1050,1807,1808,1810,1812,1814,1816,1818,1820,1822,1824,1827,1829,1831,1834,1836],{"class":1052,"line":1088},[1050,1809,1135],{"class":1060},[1050,1811,1138],{"class":1064},[1050,1813,1141],{"class":1060},[1050,1815,1065],{"class":1064},[1050,1817,1147],{"class":1146},[1050,1819,1065],{"class":1064},[1050,1821,1153],{"class":1152},[1050,1823,1221],{"class":1064},[1050,1825,1826],{"class":1162},"title__exact",[1050,1828,1138],{"class":1064},[1050,1830,1169],{"class":1168},[1050,1832,1833],{"class":1172},"Django Tutorial",[1050,1835,1169],{"class":1168},[1050,1837,1233],{"class":1064},[1050,1839,1840,1842,1844,1846,1848,1850,1852,1854,1856,1859,1861,1863,1866,1868,1870],{"class":1052,"line":1105},[1050,1841,1135],{"class":1060},[1050,1843,1138],{"class":1064},[1050,1845,1141],{"class":1060},[1050,1847,1065],{"class":1064},[1050,1849,1147],{"class":1146},[1050,1851,1065],{"class":1064},[1050,1853,1153],{"class":1152},[1050,1855,1221],{"class":1064},[1050,1857,1858],{"class":1162},"title__iexact",[1050,1860,1138],{"class":1064},[1050,1862,1169],{"class":1168},[1050,1864,1865],{"class":1172},"django tutorial",[1050,1867,1169],{"class":1168},[1050,1869,1282],{"class":1064},[1050,1871,1872],{"class":1128},"  # Case-insensitive\n",[1050,1874,1875,1877,1879,1881,1883,1885,1887,1889,1891,1894,1896,1898,1901,1903],{"class":1052,"line":1118},[1050,1876,1135],{"class":1060},[1050,1878,1138],{"class":1064},[1050,1880,1141],{"class":1060},[1050,1882,1065],{"class":1064},[1050,1884,1147],{"class":1146},[1050,1886,1065],{"class":1064},[1050,1888,1153],{"class":1152},[1050,1890,1221],{"class":1064},[1050,1892,1893],{"class":1162},"title__contains",[1050,1895,1138],{"class":1064},[1050,1897,1169],{"class":1168},[1050,1899,1900],{"class":1172},"Django",[1050,1902,1169],{"class":1168},[1050,1904,1233],{"class":1064},[1050,1906,1907,1909,1911,1913,1915,1917,1919,1921,1923,1925,1927,1929,1931,1933,1935],{"class":1052,"line":1125},[1050,1908,1135],{"class":1060},[1050,1910,1138],{"class":1064},[1050,1912,1141],{"class":1060},[1050,1914,1065],{"class":1064},[1050,1916,1147],{"class":1146},[1050,1918,1065],{"class":1064},[1050,1920,1153],{"class":1152},[1050,1922,1221],{"class":1064},[1050,1924,1505],{"class":1162},[1050,1926,1138],{"class":1064},[1050,1928,1169],{"class":1168},[1050,1930,1512],{"class":1172},[1050,1932,1169],{"class":1168},[1050,1934,1282],{"class":1064},[1050,1936,1937],{"class":1128},"       # Case-insensitive\n",[1050,1939,1940,1942,1944,1946,1948,1950,1952,1954,1956,1959,1961,1963,1966,1968],{"class":1052,"line":1132},[1050,1941,1135],{"class":1060},[1050,1943,1138],{"class":1064},[1050,1945,1141],{"class":1060},[1050,1947,1065],{"class":1064},[1050,1949,1147],{"class":1146},[1050,1951,1065],{"class":1064},[1050,1953,1153],{"class":1152},[1050,1955,1221],{"class":1064},[1050,1957,1958],{"class":1162},"title__startswith",[1050,1960,1138],{"class":1064},[1050,1962,1169],{"class":1168},[1050,1964,1965],{"class":1172},"How to",[1050,1967,1169],{"class":1168},[1050,1969,1233],{"class":1064},[1050,1971,1972,1974,1976,1978,1980,1982,1984,1986,1988,1991,1993,1995,1998,2000],{"class":1052,"line":1159},[1050,1973,1135],{"class":1060},[1050,1975,1138],{"class":1064},[1050,1977,1141],{"class":1060},[1050,1979,1065],{"class":1064},[1050,1981,1147],{"class":1146},[1050,1983,1065],{"class":1064},[1050,1985,1153],{"class":1152},[1050,1987,1221],{"class":1064},[1050,1989,1990],{"class":1162},"title__endswith",[1050,1992,1138],{"class":1064},[1050,1994,1169],{"class":1168},[1050,1996,1997],{"class":1172},"Tutorial",[1050,1999,1169],{"class":1168},[1050,2001,1233],{"class":1064},[1050,2003,2004,2006,2008,2010,2012,2014,2016,2018,2020,2023,2025,2027,2030,2032,2034],{"class":1052,"line":1181},[1050,2005,1135],{"class":1060},[1050,2007,1138],{"class":1064},[1050,2009,1141],{"class":1060},[1050,2011,1065],{"class":1064},[1050,2013,1147],{"class":1146},[1050,2015,1065],{"class":1064},[1050,2017,1153],{"class":1152},[1050,2019,1221],{"class":1064},[1050,2021,2022],{"class":1162},"title__istartswith",[1050,2024,1138],{"class":1064},[1050,2026,1169],{"class":1168},[1050,2028,2029],{"class":1172},"how to",[1050,2031,1169],{"class":1168},[1050,2033,1282],{"class":1064},[1050,2035,2036],{"class":1128},"     # Case-insensitive\n",[1050,2038,2039,2041,2043,2045,2047,2049,2051,2053,2055,2058,2060,2062,2065,2067,2069],{"class":1052,"line":1195},[1050,2040,1135],{"class":1060},[1050,2042,1138],{"class":1064},[1050,2044,1141],{"class":1060},[1050,2046,1065],{"class":1064},[1050,2048,1147],{"class":1146},[1050,2050,1065],{"class":1064},[1050,2052,1153],{"class":1152},[1050,2054,1221],{"class":1064},[1050,2056,2057],{"class":1162},"title__iendswith",[1050,2059,1138],{"class":1064},[1050,2061,1169],{"class":1168},[1050,2063,2064],{"class":1172},"tutorial",[1050,2066,1169],{"class":1168},[1050,2068,1282],{"class":1064},[1050,2070,2036],{"class":1128},[1050,2072,2073],{"class":1052,"line":1236},[1050,2074,1122],{"emptyLinePlaceholder":1121},[1050,2076,2077],{"class":1052,"line":1241},[1050,2078,2079],{"class":1128},"# Numeric field lookups\n",[1050,2081,2082,2084,2086,2088,2090,2092,2094,2096,2098,2101,2103,2106],{"class":1052,"line":1246},[1050,2083,1135],{"class":1060},[1050,2085,1138],{"class":1064},[1050,2087,1141],{"class":1060},[1050,2089,1065],{"class":1064},[1050,2091,1147],{"class":1146},[1050,2093,1065],{"class":1064},[1050,2095,1153],{"class":1152},[1050,2097,1221],{"class":1064},[1050,2099,2100],{"class":1162},"view_count__exact",[1050,2102,1138],{"class":1064},[1050,2104,2105],{"class":1229},"1000",[1050,2107,1233],{"class":1064},[1050,2109,2110,2112,2114,2116,2118,2120,2122,2124,2126,2129,2131,2133,2135],{"class":1052,"line":1252},[1050,2111,1135],{"class":1060},[1050,2113,1138],{"class":1064},[1050,2115,1141],{"class":1060},[1050,2117,1065],{"class":1064},[1050,2119,1147],{"class":1146},[1050,2121,1065],{"class":1064},[1050,2123,1153],{"class":1152},[1050,2125,1221],{"class":1064},[1050,2127,2128],{"class":1162},"view_count__gt",[1050,2130,1138],{"class":1064},[1050,2132,2105],{"class":1229},[1050,2134,1282],{"class":1064},[1050,2136,2137],{"class":1128},"            # Greater than\n",[1050,2139,2140,2142,2144,2146,2148,2150,2152,2154,2156,2159,2161,2163,2165],{"class":1052,"line":1288},[1050,2141,1135],{"class":1060},[1050,2143,1138],{"class":1064},[1050,2145,1141],{"class":1060},[1050,2147,1065],{"class":1064},[1050,2149,1147],{"class":1146},[1050,2151,1065],{"class":1064},[1050,2153,1153],{"class":1152},[1050,2155,1221],{"class":1064},[1050,2157,2158],{"class":1162},"view_count__gte",[1050,2160,1138],{"class":1064},[1050,2162,2105],{"class":1229},[1050,2164,1282],{"class":1064},[1050,2166,2167],{"class":1128},"           # Greater than or equal\n",[1050,2169,2170,2172,2174,2176,2178,2180,2182,2184,2186,2189,2191,2193,2195],{"class":1052,"line":1309},[1050,2171,1135],{"class":1060},[1050,2173,1138],{"class":1064},[1050,2175,1141],{"class":1060},[1050,2177,1065],{"class":1064},[1050,2179,1147],{"class":1146},[1050,2181,1065],{"class":1064},[1050,2183,1153],{"class":1152},[1050,2185,1221],{"class":1064},[1050,2187,2188],{"class":1162},"view_count__lt",[1050,2190,1138],{"class":1064},[1050,2192,2105],{"class":1229},[1050,2194,1282],{"class":1064},[1050,2196,2197],{"class":1128},"            # Less than\n",[1050,2199,2200,2202,2204,2206,2208,2210,2212,2214,2216,2219,2221,2223,2225],{"class":1052,"line":1346},[1050,2201,1135],{"class":1060},[1050,2203,1138],{"class":1064},[1050,2205,1141],{"class":1060},[1050,2207,1065],{"class":1064},[1050,2209,1147],{"class":1146},[1050,2211,1065],{"class":1064},[1050,2213,1153],{"class":1152},[1050,2215,1221],{"class":1064},[1050,2217,2218],{"class":1162},"view_count__lte",[1050,2220,1138],{"class":1064},[1050,2222,2105],{"class":1229},[1050,2224,1282],{"class":1064},[1050,2226,2227],{"class":1128},"           # Less than or equal\n",[1050,2229,2230,2232,2234,2236,2238,2240,2242,2244,2246,2249,2252,2255,2257,2260,2262],{"class":1052,"line":1351},[1050,2231,1135],{"class":1060},[1050,2233,1138],{"class":1064},[1050,2235,1141],{"class":1060},[1050,2237,1065],{"class":1064},[1050,2239,1147],{"class":1146},[1050,2241,1065],{"class":1064},[1050,2243,1153],{"class":1152},[1050,2245,1221],{"class":1064},[1050,2247,2248],{"class":1162},"view_count__range",[1050,2250,2251],{"class":1064},"=(",[1050,2253,2254],{"class":1229},"100",[1050,2256,1082],{"class":1064},[1050,2258,2259],{"class":1229}," 1000",[1050,2261,1760],{"class":1064},[1050,2263,2264],{"class":1128},"  # Between values\n",[1050,2266,2267],{"class":1052,"line":1357},[1050,2268,1122],{"emptyLinePlaceholder":1121},[1050,2270,2271],{"class":1052,"line":1392},[1050,2272,2273],{"class":1128},"# Date and time lookups\n",[1050,2275,2276,2278,2280,2282,2285,2287],{"class":1052,"line":1415},[1050,2277,1057],{"class":1056},[1050,2279,1110],{"class":1060},[1050,2281,1076],{"class":1056},[1050,2283,2284],{"class":1060}," date",[1050,2286,1082],{"class":1064},[1050,2288,2289],{"class":1060}," datetime\n",[1050,2291,2292],{"class":1052,"line":1420},[1050,2293,1122],{"emptyLinePlaceholder":1121},[1050,2295,2296,2298,2300,2302,2304,2306,2308,2310,2312,2315,2317,2320],{"class":1052,"line":1426},[1050,2297,1135],{"class":1060},[1050,2299,1138],{"class":1064},[1050,2301,1141],{"class":1060},[1050,2303,1065],{"class":1064},[1050,2305,1147],{"class":1146},[1050,2307,1065],{"class":1064},[1050,2309,1153],{"class":1152},[1050,2311,1221],{"class":1064},[1050,2313,2314],{"class":1162},"created_at__year",[1050,2316,1138],{"class":1064},[1050,2318,2319],{"class":1229},"2023",[1050,2321,1233],{"class":1064},[1050,2323,2324,2326,2328,2330,2332,2334,2336,2338,2340,2343,2345,2348],{"class":1052,"line":1459},[1050,2325,1135],{"class":1060},[1050,2327,1138],{"class":1064},[1050,2329,1141],{"class":1060},[1050,2331,1065],{"class":1064},[1050,2333,1147],{"class":1146},[1050,2335,1065],{"class":1064},[1050,2337,1153],{"class":1152},[1050,2339,1221],{"class":1064},[1050,2341,2342],{"class":1162},"created_at__month",[1050,2344,1138],{"class":1064},[1050,2346,2347],{"class":1229},"12",[1050,2349,1233],{"class":1064},[1050,2351,2352,2354,2356,2358,2360,2362,2364,2366,2368,2371,2373,2376],{"class":1052,"line":1482},[1050,2353,1135],{"class":1060},[1050,2355,1138],{"class":1064},[1050,2357,1141],{"class":1060},[1050,2359,1065],{"class":1064},[1050,2361,1147],{"class":1146},[1050,2363,1065],{"class":1064},[1050,2365,1153],{"class":1152},[1050,2367,1221],{"class":1064},[1050,2369,2370],{"class":1162},"created_at__day",[1050,2372,1138],{"class":1064},[1050,2374,2375],{"class":1229},"25",[1050,2377,1233],{"class":1064},[1050,2379,2380,2382,2384,2386,2388,2390,2392,2394,2396,2399,2401,2404],{"class":1052,"line":1487},[1050,2381,1135],{"class":1060},[1050,2383,1138],{"class":1064},[1050,2385,1141],{"class":1060},[1050,2387,1065],{"class":1064},[1050,2389,1147],{"class":1146},[1050,2391,1065],{"class":1064},[1050,2393,1153],{"class":1152},[1050,2395,1221],{"class":1064},[1050,2397,2398],{"class":1162},"created_at__week",[1050,2400,1138],{"class":1064},[1050,2402,2403],{"class":1229},"52",[1050,2405,1233],{"class":1064},[1050,2407,2408,2410,2412,2414,2416,2418,2420,2422,2424,2427,2429,2432,2434],{"class":1052,"line":1493},[1050,2409,1135],{"class":1060},[1050,2411,1138],{"class":1064},[1050,2413,1141],{"class":1060},[1050,2415,1065],{"class":1064},[1050,2417,1147],{"class":1146},[1050,2419,1065],{"class":1064},[1050,2421,1153],{"class":1152},[1050,2423,1221],{"class":1064},[1050,2425,2426],{"class":1162},"created_at__week_day",[1050,2428,1138],{"class":1064},[1050,2430,2431],{"class":1229},"1",[1050,2433,1282],{"class":1064},[1050,2435,2436],{"class":1128},"         # Sunday = 1\n",[1050,2438,2439,2441,2443,2445,2447,2449,2451,2453,2455,2458,2460,2463,2465],{"class":1052,"line":1539},[1050,2440,1135],{"class":1060},[1050,2442,1138],{"class":1064},[1050,2444,1141],{"class":1060},[1050,2446,1065],{"class":1064},[1050,2448,1147],{"class":1146},[1050,2450,1065],{"class":1064},[1050,2452,1153],{"class":1152},[1050,2454,1221],{"class":1064},[1050,2456,2457],{"class":1162},"created_at__quarter",[1050,2459,1138],{"class":1064},[1050,2461,2462],{"class":1229},"4",[1050,2464,1282],{"class":1064},[1050,2466,2467],{"class":1128},"          # Q4\n",[1050,2469,2470,2472,2474,2476,2478,2480,2482,2484,2486,2489,2491,2494],{"class":1052,"line":1584},[1050,2471,1135],{"class":1060},[1050,2473,1138],{"class":1064},[1050,2475,1141],{"class":1060},[1050,2477,1065],{"class":1064},[1050,2479,1147],{"class":1146},[1050,2481,1065],{"class":1064},[1050,2483,1153],{"class":1152},[1050,2485,1221],{"class":1064},[1050,2487,2488],{"class":1162},"created_at__hour",[1050,2490,1138],{"class":1064},[1050,2492,2493],{"class":1229},"14",[1050,2495,1233],{"class":1064},[1050,2497,2498,2500,2502,2504,2506,2508,2510,2512,2514,2517,2519,2521],{"class":1052,"line":1623},[1050,2499,1135],{"class":1060},[1050,2501,1138],{"class":1064},[1050,2503,1141],{"class":1060},[1050,2505,1065],{"class":1064},[1050,2507,1147],{"class":1146},[1050,2509,1065],{"class":1064},[1050,2511,1153],{"class":1152},[1050,2513,1221],{"class":1064},[1050,2515,2516],{"class":1162},"created_at__minute",[1050,2518,1138],{"class":1064},[1050,2520,1230],{"class":1229},[1050,2522,1233],{"class":1064},[1050,2524,2525,2527,2529,2531,2533,2535,2537,2539,2541,2544,2546,2549],{"class":1052,"line":1628},[1050,2526,1135],{"class":1060},[1050,2528,1138],{"class":1064},[1050,2530,1141],{"class":1060},[1050,2532,1065],{"class":1064},[1050,2534,1147],{"class":1146},[1050,2536,1065],{"class":1064},[1050,2538,1153],{"class":1152},[1050,2540,1221],{"class":1064},[1050,2542,2543],{"class":1162},"created_at__second",[1050,2545,1138],{"class":1064},[1050,2547,2548],{"class":1229},"45",[1050,2550,1233],{"class":1064},[1050,2552,2553],{"class":1052,"line":1662},[1050,2554,1122],{"emptyLinePlaceholder":1121},[1050,2556,2557],{"class":1052,"line":1667},[1050,2558,2559],{"class":1128},"# Date-only comparisons\n",[1050,2561,2562,2565,2567,2569,2571,2574],{"class":1052,"line":1673},[1050,2563,2564],{"class":1060},"today ",[1050,2566,1138],{"class":1064},[1050,2568,2284],{"class":1060},[1050,2570,1065],{"class":1064},[1050,2572,2573],{"class":1152},"today",[1050,2575,2576],{"class":1064},"()\n",[1050,2578,2579,2581,2583,2585,2587,2589,2591,2593,2595,2598,2600,2602],{"class":1052,"line":1692},[1050,2580,1135],{"class":1060},[1050,2582,1138],{"class":1064},[1050,2584,1141],{"class":1060},[1050,2586,1065],{"class":1064},[1050,2588,1147],{"class":1146},[1050,2590,1065],{"class":1064},[1050,2592,1153],{"class":1152},[1050,2594,1221],{"class":1064},[1050,2596,2597],{"class":1162},"created_at__date",[1050,2599,1138],{"class":1064},[1050,2601,2573],{"class":1152},[1050,2603,1233],{"class":1064},[1050,2605,2606,2608,2610,2612,2614,2616,2618,2620,2622,2625,2627,2629],{"class":1052,"line":1718},[1050,2607,1135],{"class":1060},[1050,2609,1138],{"class":1064},[1050,2611,1141],{"class":1060},[1050,2613,1065],{"class":1064},[1050,2615,1147],{"class":1146},[1050,2617,1065],{"class":1064},[1050,2619,1153],{"class":1152},[1050,2621,1221],{"class":1064},[1050,2623,2624],{"class":1162},"created_at__date__gte",[1050,2626,1138],{"class":1064},[1050,2628,2573],{"class":1152},[1050,2630,1233],{"class":1064},[1050,2632,2633],{"class":1052,"line":1766},[1050,2634,1122],{"emptyLinePlaceholder":1121},[1050,2636,2637],{"class":1052,"line":1789},[1050,2638,2639],{"class":1128},"# Time-only comparisons\n",[1050,2641,2643,2645,2647,2649],{"class":1052,"line":2642},38,[1050,2644,1057],{"class":1056},[1050,2646,1110],{"class":1060},[1050,2648,1076],{"class":1056},[1050,2650,2651],{"class":1060}," time\n",[1050,2653,2655,2658,2660,2663,2665,2668,2670,2673],{"class":1052,"line":2654},39,[1050,2656,2657],{"class":1060},"morning ",[1050,2659,1138],{"class":1064},[1050,2661,2662],{"class":1152}," time",[1050,2664,1221],{"class":1064},[1050,2666,2667],{"class":1229},"9",[1050,2669,1082],{"class":1064},[1050,2671,2672],{"class":1229}," 0",[1050,2674,1233],{"class":1064},[1050,2676,2678,2680,2682,2684,2686,2688,2690,2692,2694,2697,2699,2702],{"class":1052,"line":2677},40,[1050,2679,1135],{"class":1060},[1050,2681,1138],{"class":1064},[1050,2683,1141],{"class":1060},[1050,2685,1065],{"class":1064},[1050,2687,1147],{"class":1146},[1050,2689,1065],{"class":1064},[1050,2691,1153],{"class":1152},[1050,2693,1221],{"class":1064},[1050,2695,2696],{"class":1162},"created_at__time__gte",[1050,2698,1138],{"class":1064},[1050,2700,2701],{"class":1152},"morning",[1050,2703,1233],{"class":1064},[1050,2705,2707],{"class":1052,"line":2706},41,[1050,2708,1122],{"emptyLinePlaceholder":1121},[1050,2710,2712],{"class":1052,"line":2711},42,[1050,2713,2714],{"class":1128},"# ISO week date\n",[1050,2716,2718,2720,2722,2724,2726,2728,2730,2732,2734,2737,2739,2741,2743],{"class":1052,"line":2717},43,[1050,2719,1135],{"class":1060},[1050,2721,1138],{"class":1064},[1050,2723,1141],{"class":1060},[1050,2725,1065],{"class":1064},[1050,2727,1147],{"class":1146},[1050,2729,1065],{"class":1064},[1050,2731,1153],{"class":1152},[1050,2733,1221],{"class":1064},[1050,2735,2736],{"class":1162},"created_at__iso_week_day",[1050,2738,1138],{"class":1064},[1050,2740,2431],{"class":1229},[1050,2742,1282],{"class":1064},[1050,2744,2745],{"class":1128},"     # Monday = 1\n",[1050,2747,2749,2751,2753,2755,2757,2759,2761,2763,2765,2768,2770,2772],{"class":1052,"line":2748},44,[1050,2750,1135],{"class":1060},[1050,2752,1138],{"class":1064},[1050,2754,1141],{"class":1060},[1050,2756,1065],{"class":1064},[1050,2758,1147],{"class":1146},[1050,2760,1065],{"class":1064},[1050,2762,1153],{"class":1152},[1050,2764,1221],{"class":1064},[1050,2766,2767],{"class":1162},"created_at__iso_year",[1050,2769,1138],{"class":1064},[1050,2771,2319],{"class":1229},[1050,2773,1233],{"class":1064},[1050,2775,2777],{"class":1052,"line":2776},45,[1050,2778,1122],{"emptyLinePlaceholder":1121},[1050,2780,2782],{"class":1052,"line":2781},46,[1050,2783,2784],{"class":1128},"# Null and boolean lookups\n",[1050,2786,2788,2790,2792,2794,2796,2798,2800,2802,2804,2807,2809,2811,2813],{"class":1052,"line":2787},47,[1050,2789,1135],{"class":1060},[1050,2791,1138],{"class":1064},[1050,2793,1141],{"class":1060},[1050,2795,1065],{"class":1064},[1050,2797,1147],{"class":1146},[1050,2799,1065],{"class":1064},[1050,2801,1153],{"class":1152},[1050,2803,1221],{"class":1064},[1050,2805,2806],{"class":1162},"published_at__isnull",[1050,2808,1138],{"class":1064},[1050,2810,1190],{"class":1189},[1050,2812,1282],{"class":1064},[1050,2814,2815],{"class":1128},"     # Unpublished posts\n",[1050,2817,2819,2821,2823,2825,2827,2829,2831,2833,2835,2837,2839,2842,2844],{"class":1052,"line":2818},48,[1050,2820,1135],{"class":1060},[1050,2822,1138],{"class":1064},[1050,2824,1141],{"class":1060},[1050,2826,1065],{"class":1064},[1050,2828,1147],{"class":1146},[1050,2830,1065],{"class":1064},[1050,2832,1153],{"class":1152},[1050,2834,1221],{"class":1064},[1050,2836,2806],{"class":1162},[1050,2838,1138],{"class":1064},[1050,2840,2841],{"class":1189},"False",[1050,2843,1282],{"class":1064},[1050,2845,2846],{"class":1128},"    # Published posts\n",[1050,2848,2850,2852,2854,2856,2858,2860,2862,2864,2866,2869,2871,2873],{"class":1052,"line":2849},49,[1050,2851,1135],{"class":1060},[1050,2853,1138],{"class":1064},[1050,2855,1141],{"class":1060},[1050,2857,1065],{"class":1064},[1050,2859,1147],{"class":1146},[1050,2861,1065],{"class":1064},[1050,2863,1153],{"class":1152},[1050,2865,1221],{"class":1064},[1050,2867,2868],{"class":1162},"is_featured",[1050,2870,1138],{"class":1064},[1050,2872,1190],{"class":1189},[1050,2874,1233],{"class":1064},[1050,2876,2878,2880,2882,2884,2886,2888,2890,2892,2894,2897,2899,2901,2903],{"class":1052,"line":2877},50,[1050,2879,1135],{"class":1060},[1050,2881,1138],{"class":1064},[1050,2883,1141],{"class":1060},[1050,2885,1065],{"class":1064},[1050,2887,1147],{"class":1146},[1050,2889,1065],{"class":1064},[1050,2891,1153],{"class":1152},[1050,2893,1221],{"class":1064},[1050,2895,2896],{"class":1162},"is_featured__exact",[1050,2898,1138],{"class":1064},[1050,2900,1190],{"class":1189},[1050,2902,1282],{"class":1064},[1050,2904,2905],{"class":1128},"       # Equivalent\n",[1050,2907,2909],{"class":1052,"line":2908},51,[1050,2910,1122],{"emptyLinePlaceholder":1121},[1050,2912,2914],{"class":1052,"line":2913},52,[1050,2915,2916],{"class":1128},"# List membership\n",[1050,2918,2920,2923,2925,2928,2930,2932,2935,2937,2940,2942,2945,2947,2950],{"class":1052,"line":2919},53,[1050,2921,2922],{"class":1060},"post_ids ",[1050,2924,1138],{"class":1064},[1050,2926,2927],{"class":1064}," [",[1050,2929,2431],{"class":1229},[1050,2931,1082],{"class":1064},[1050,2933,2934],{"class":1229}," 2",[1050,2936,1082],{"class":1064},[1050,2938,2939],{"class":1229}," 3",[1050,2941,1082],{"class":1064},[1050,2943,2944],{"class":1229}," 4",[1050,2946,1082],{"class":1064},[1050,2948,2949],{"class":1229}," 5",[1050,2951,2952],{"class":1064},"]\n",[1050,2954,2956,2958,2960,2962,2964,2966,2968,2970,2972,2975,2977,2980],{"class":1052,"line":2955},54,[1050,2957,1135],{"class":1060},[1050,2959,1138],{"class":1064},[1050,2961,1141],{"class":1060},[1050,2963,1065],{"class":1064},[1050,2965,1147],{"class":1146},[1050,2967,1065],{"class":1064},[1050,2969,1153],{"class":1152},[1050,2971,1221],{"class":1064},[1050,2973,2974],{"class":1162},"id__in",[1050,2976,1138],{"class":1064},[1050,2978,2979],{"class":1152},"post_ids",[1050,2981,1233],{"class":1064},[1050,2983,2985],{"class":1052,"line":2984},55,[1050,2986,1122],{"emptyLinePlaceholder":1121},[1050,2988,2990,2993,2995,2997,2999,3002,3004,3006,3009,3011,3013,3015,3017,3020,3022],{"class":1052,"line":2989},56,[1050,2991,2992],{"class":1060},"categories ",[1050,2994,1138],{"class":1064},[1050,2996,2927],{"class":1064},[1050,2998,1169],{"class":1168},[1050,3000,3001],{"class":1172},"tech",[1050,3003,1169],{"class":1168},[1050,3005,1082],{"class":1064},[1050,3007,3008],{"class":1168}," '",[1050,3010,1558],{"class":1172},[1050,3012,1169],{"class":1168},[1050,3014,1082],{"class":1064},[1050,3016,3008],{"class":1168},[1050,3018,3019],{"class":1172},"web-development",[1050,3021,1169],{"class":1168},[1050,3023,2952],{"class":1064},[1050,3025,3027,3029,3031,3033,3035,3037,3039,3041,3043,3046,3048,3051],{"class":1052,"line":3026},57,[1050,3028,1135],{"class":1060},[1050,3030,1138],{"class":1064},[1050,3032,1141],{"class":1060},[1050,3034,1065],{"class":1064},[1050,3036,1147],{"class":1146},[1050,3038,1065],{"class":1064},[1050,3040,1153],{"class":1152},[1050,3042,1221],{"class":1064},[1050,3044,3045],{"class":1162},"category__slug__in",[1050,3047,1138],{"class":1064},[1050,3049,3050],{"class":1152},"categories",[1050,3052,1233],{"class":1064},[1050,3054,3056],{"class":1052,"line":3055},58,[1050,3057,1122],{"emptyLinePlaceholder":1121},[1050,3059,3061],{"class":1052,"line":3060},59,[1050,3062,3063],{"class":1128},"# Subquery filtering\n",[1050,3065,3067,3070,3072,3075,3077,3079,3081,3083,3085,3088,3090,3093],{"class":1052,"line":3066},60,[1050,3068,3069],{"class":1060},"popular_authors ",[1050,3071,1138],{"class":1064},[1050,3073,3074],{"class":1060}," Author",[1050,3076,1065],{"class":1064},[1050,3078,1147],{"class":1146},[1050,3080,1065],{"class":1064},[1050,3082,1153],{"class":1152},[1050,3084,1221],{"class":1064},[1050,3086,3087],{"class":1162},"posts__view_count__gt",[1050,3089,1138],{"class":1064},[1050,3091,3092],{"class":1229},"10000",[1050,3094,1233],{"class":1064},[1050,3096,3098,3100,3102,3104,3106,3108,3110,3112,3114,3117,3119,3122],{"class":1052,"line":3097},61,[1050,3099,1135],{"class":1060},[1050,3101,1138],{"class":1064},[1050,3103,1141],{"class":1060},[1050,3105,1065],{"class":1064},[1050,3107,1147],{"class":1146},[1050,3109,1065],{"class":1064},[1050,3111,1153],{"class":1152},[1050,3113,1221],{"class":1064},[1050,3115,3116],{"class":1162},"author__in",[1050,3118,1138],{"class":1064},[1050,3120,3121],{"class":1152},"popular_authors",[1050,3123,1233],{"class":1064},[1050,3125,3127],{"class":1052,"line":3126},62,[1050,3128,1122],{"emptyLinePlaceholder":1121},[1050,3130,3132],{"class":1052,"line":3131},63,[1050,3133,3134],{"class":1128},"# Regular expressions (database-dependent)\n",[1050,3136,3138,3140,3142,3144,3146,3148,3150,3152,3154,3157,3159,3163,3165,3169,3171,3175,3178,3181,3183,3186,3188,3190],{"class":1052,"line":3137},64,[1050,3139,1135],{"class":1060},[1050,3141,1138],{"class":1064},[1050,3143,1141],{"class":1060},[1050,3145,1065],{"class":1064},[1050,3147,1147],{"class":1146},[1050,3149,1065],{"class":1064},[1050,3151,1153],{"class":1152},[1050,3153,1221],{"class":1064},[1050,3155,3156],{"class":1162},"title__regex",[1050,3158,1138],{"class":1064},[1050,3160,3162],{"class":3161},"s5Kfy","r",[1050,3164,1169],{"class":1168},[1050,3166,3168],{"class":3167},"sRJPX","^",[1050,3170,1221],{"class":1064},[1050,3172,3174],{"class":3173},"s27EL","How",[1050,3176,3177],{"class":1214},"|",[1050,3179,3180],{"class":3173},"What",[1050,3182,3177],{"class":1214},[1050,3184,3185],{"class":3173},"Why",[1050,3187,1282],{"class":1064},[1050,3189,1169],{"class":1168},[1050,3191,1233],{"class":1064},[1050,3193,3195,3197,3199,3201,3203,3205,3207,3209,3211,3214,3216,3218,3220,3222,3224,3227,3229,3232,3234,3237,3239,3241,3243],{"class":1052,"line":3194},65,[1050,3196,1135],{"class":1060},[1050,3198,1138],{"class":1064},[1050,3200,1141],{"class":1060},[1050,3202,1065],{"class":1064},[1050,3204,1147],{"class":1146},[1050,3206,1065],{"class":1064},[1050,3208,1153],{"class":1152},[1050,3210,1221],{"class":1064},[1050,3212,3213],{"class":1162},"title__iregex",[1050,3215,1138],{"class":1064},[1050,3217,3162],{"class":3161},[1050,3219,1169],{"class":1168},[1050,3221,3168],{"class":3167},[1050,3223,1221],{"class":1064},[1050,3225,3226],{"class":3173},"how",[1050,3228,3177],{"class":1214},[1050,3230,3231],{"class":3173},"what",[1050,3233,3177],{"class":1214},[1050,3235,3236],{"class":3173},"why",[1050,3238,1282],{"class":1064},[1050,3240,1169],{"class":1168},[1050,3242,1282],{"class":1064},[1050,3244,1872],{"class":1128},[1050,3246,3248],{"class":1052,"line":3247},66,[1050,3249,1122],{"emptyLinePlaceholder":1121},[1050,3251,3253],{"class":1052,"line":3252},67,[1050,3254,3255],{"class":1128},"# Full-text search (PostgreSQL)\n",[1050,3257,3259],{"class":1052,"line":3258},68,[1050,3260,3261],{"class":1128},"# posts = Post.objects.filter(title__search='django tutorial')\n",[1035,3263,3265],{"id":3264},"relationship-filtering","Relationship Filtering",[1040,3267,3269],{"className":1042,"code":3268,"language":1044,"meta":1045,"style":1045},"# Forward relationship filtering\nposts = Post.objects.filter(author__name='John Doe')\nposts = Post.objects.filter(author__email__endswith='@company.com')\nposts = Post.objects.filter(category__parent__name='Technology')\n\n# Reverse relationship filtering\nauthors = Author.objects.filter(posts__status='published')\ncategories = Category.objects.filter(posts__view_count__gt=1000)\n\n# Many-to-many filtering\nposts = Post.objects.filter(tags__name='Django')\nposts = Post.objects.filter(tags__name__in=['Django', 'Python'])\n\n# Multiple conditions on same relationship\n# Posts that have both 'Django' and 'Python' tags\nposts = Post.objects.filter(tags__name='Django').filter(tags__name='Python')\n\n# Posts by authors who have written about Django\nauthors_writing_django = Author.objects.filter(posts__tags__name='Django')\nposts = Post.objects.filter(author__in=authors_writing_django)\n\n# Complex relationship queries\n# Authors who have posts in multiple categories\nmulti_category_authors = Author.objects.filter(\n    posts__category__name='Programming'\n).filter(\n    posts__category__name='Web Development'\n).distinct()\n\n# Posts by prolific authors (more than 10 posts)\nfrom django.db.models import Count\nprolific_authors = Author.objects.annotate(\n    post_count=Count('posts')\n).filter(post_count__gt=10)\n\nposts = Post.objects.filter(author__in=prolific_authors)\n",[1047,3270,3271,3276,3308,3339,3371,3375,3380,3412,3439,3443,3448,3478,3520,3524,3529,3534,3581,3585,3590,3622,3649,3653,3658,3663,3682,3697,3705,3718,3727,3731,3736,3755,3775,3796,3814,3818],{"__ignoreMap":1045},[1050,3272,3273],{"class":1052,"line":1053},[1050,3274,3275],{"class":1128},"# Forward relationship filtering\n",[1050,3277,3278,3280,3282,3284,3286,3288,3290,3292,3294,3297,3299,3301,3304,3306],{"class":1052,"line":1088},[1050,3279,1135],{"class":1060},[1050,3281,1138],{"class":1064},[1050,3283,1141],{"class":1060},[1050,3285,1065],{"class":1064},[1050,3287,1147],{"class":1146},[1050,3289,1065],{"class":1064},[1050,3291,1153],{"class":1152},[1050,3293,1221],{"class":1064},[1050,3295,3296],{"class":1162},"author__name",[1050,3298,1138],{"class":1064},[1050,3300,1169],{"class":1168},[1050,3302,3303],{"class":1172},"John Doe",[1050,3305,1169],{"class":1168},[1050,3307,1233],{"class":1064},[1050,3309,3310,3312,3314,3316,3318,3320,3322,3324,3326,3328,3330,3332,3335,3337],{"class":1052,"line":1105},[1050,3311,1135],{"class":1060},[1050,3313,1138],{"class":1064},[1050,3315,1141],{"class":1060},[1050,3317,1065],{"class":1064},[1050,3319,1147],{"class":1146},[1050,3321,1065],{"class":1064},[1050,3323,1153],{"class":1152},[1050,3325,1221],{"class":1064},[1050,3327,1401],{"class":1162},[1050,3329,1138],{"class":1064},[1050,3331,1169],{"class":1168},[1050,3333,3334],{"class":1172},"@company.com",[1050,3336,1169],{"class":1168},[1050,3338,1233],{"class":1064},[1050,3340,3341,3343,3345,3347,3349,3351,3353,3355,3357,3360,3362,3364,3367,3369],{"class":1052,"line":1118},[1050,3342,1135],{"class":1060},[1050,3344,1138],{"class":1064},[1050,3346,1141],{"class":1060},[1050,3348,1065],{"class":1064},[1050,3350,1147],{"class":1146},[1050,3352,1065],{"class":1064},[1050,3354,1153],{"class":1152},[1050,3356,1221],{"class":1064},[1050,3358,3359],{"class":1162},"category__parent__name",[1050,3361,1138],{"class":1064},[1050,3363,1169],{"class":1168},[1050,3365,3366],{"class":1172},"Technology",[1050,3368,1169],{"class":1168},[1050,3370,1233],{"class":1064},[1050,3372,3373],{"class":1052,"line":1125},[1050,3374,1122],{"emptyLinePlaceholder":1121},[1050,3376,3377],{"class":1052,"line":1132},[1050,3378,3379],{"class":1128},"# Reverse relationship filtering\n",[1050,3381,3382,3385,3387,3389,3391,3393,3395,3397,3399,3402,3404,3406,3408,3410],{"class":1052,"line":1159},[1050,3383,3384],{"class":1060},"authors ",[1050,3386,1138],{"class":1064},[1050,3388,3074],{"class":1060},[1050,3390,1065],{"class":1064},[1050,3392,1147],{"class":1146},[1050,3394,1065],{"class":1064},[1050,3396,1153],{"class":1152},[1050,3398,1221],{"class":1064},[1050,3400,3401],{"class":1162},"posts__status",[1050,3403,1138],{"class":1064},[1050,3405,1169],{"class":1168},[1050,3407,1173],{"class":1172},[1050,3409,1169],{"class":1168},[1050,3411,1233],{"class":1064},[1050,3413,3414,3416,3418,3421,3423,3425,3427,3429,3431,3433,3435,3437],{"class":1052,"line":1181},[1050,3415,2992],{"class":1060},[1050,3417,1138],{"class":1064},[1050,3419,3420],{"class":1060}," Category",[1050,3422,1065],{"class":1064},[1050,3424,1147],{"class":1146},[1050,3426,1065],{"class":1064},[1050,3428,1153],{"class":1152},[1050,3430,1221],{"class":1064},[1050,3432,3087],{"class":1162},[1050,3434,1138],{"class":1064},[1050,3436,2105],{"class":1229},[1050,3438,1233],{"class":1064},[1050,3440,3441],{"class":1052,"line":1195},[1050,3442,1122],{"emptyLinePlaceholder":1121},[1050,3444,3445],{"class":1052,"line":1236},[1050,3446,3447],{"class":1128},"# Many-to-many filtering\n",[1050,3449,3450,3452,3454,3456,3458,3460,3462,3464,3466,3468,3470,3472,3474,3476],{"class":1052,"line":1241},[1050,3451,1135],{"class":1060},[1050,3453,1138],{"class":1064},[1050,3455,1141],{"class":1060},[1050,3457,1065],{"class":1064},[1050,3459,1147],{"class":1146},[1050,3461,1065],{"class":1064},[1050,3463,1153],{"class":1152},[1050,3465,1221],{"class":1064},[1050,3467,1468],{"class":1162},[1050,3469,1138],{"class":1064},[1050,3471,1169],{"class":1168},[1050,3473,1900],{"class":1172},[1050,3475,1169],{"class":1168},[1050,3477,1233],{"class":1064},[1050,3479,3480,3482,3484,3486,3488,3490,3492,3494,3496,3499,3502,3504,3506,3508,3510,3512,3515,3517],{"class":1052,"line":1246},[1050,3481,1135],{"class":1060},[1050,3483,1138],{"class":1064},[1050,3485,1141],{"class":1060},[1050,3487,1065],{"class":1064},[1050,3489,1147],{"class":1146},[1050,3491,1065],{"class":1064},[1050,3493,1153],{"class":1152},[1050,3495,1221],{"class":1064},[1050,3497,3498],{"class":1162},"tags__name__in",[1050,3500,3501],{"class":1064},"=[",[1050,3503,1169],{"class":1168},[1050,3505,1900],{"class":1172},[1050,3507,1169],{"class":1168},[1050,3509,1082],{"class":1064},[1050,3511,3008],{"class":1168},[1050,3513,3514],{"class":1172},"Python",[1050,3516,1169],{"class":1168},[1050,3518,3519],{"class":1064},"])\n",[1050,3521,3522],{"class":1052,"line":1252},[1050,3523,1122],{"emptyLinePlaceholder":1121},[1050,3525,3526],{"class":1052,"line":1288},[1050,3527,3528],{"class":1128},"# Multiple conditions on same relationship\n",[1050,3530,3531],{"class":1052,"line":1309},[1050,3532,3533],{"class":1128},"# Posts that have both 'Django' and 'Python' tags\n",[1050,3535,3536,3538,3540,3542,3544,3546,3548,3550,3552,3554,3556,3558,3560,3562,3565,3567,3569,3571,3573,3575,3577,3579],{"class":1052,"line":1346},[1050,3537,1135],{"class":1060},[1050,3539,1138],{"class":1064},[1050,3541,1141],{"class":1060},[1050,3543,1065],{"class":1064},[1050,3545,1147],{"class":1146},[1050,3547,1065],{"class":1064},[1050,3549,1153],{"class":1152},[1050,3551,1221],{"class":1064},[1050,3553,1468],{"class":1162},[1050,3555,1138],{"class":1064},[1050,3557,1169],{"class":1168},[1050,3559,1900],{"class":1172},[1050,3561,1169],{"class":1168},[1050,3563,3564],{"class":1064},").",[1050,3566,1153],{"class":1152},[1050,3568,1221],{"class":1064},[1050,3570,1468],{"class":1162},[1050,3572,1138],{"class":1064},[1050,3574,1169],{"class":1168},[1050,3576,3514],{"class":1172},[1050,3578,1169],{"class":1168},[1050,3580,1233],{"class":1064},[1050,3582,3583],{"class":1052,"line":1351},[1050,3584,1122],{"emptyLinePlaceholder":1121},[1050,3586,3587],{"class":1052,"line":1357},[1050,3588,3589],{"class":1128},"# Posts by authors who have written about Django\n",[1050,3591,3592,3595,3597,3599,3601,3603,3605,3607,3609,3612,3614,3616,3618,3620],{"class":1052,"line":1392},[1050,3593,3594],{"class":1060},"authors_writing_django ",[1050,3596,1138],{"class":1064},[1050,3598,3074],{"class":1060},[1050,3600,1065],{"class":1064},[1050,3602,1147],{"class":1146},[1050,3604,1065],{"class":1064},[1050,3606,1153],{"class":1152},[1050,3608,1221],{"class":1064},[1050,3610,3611],{"class":1162},"posts__tags__name",[1050,3613,1138],{"class":1064},[1050,3615,1169],{"class":1168},[1050,3617,1900],{"class":1172},[1050,3619,1169],{"class":1168},[1050,3621,1233],{"class":1064},[1050,3623,3624,3626,3628,3630,3632,3634,3636,3638,3640,3642,3644,3647],{"class":1052,"line":1415},[1050,3625,1135],{"class":1060},[1050,3627,1138],{"class":1064},[1050,3629,1141],{"class":1060},[1050,3631,1065],{"class":1064},[1050,3633,1147],{"class":1146},[1050,3635,1065],{"class":1064},[1050,3637,1153],{"class":1152},[1050,3639,1221],{"class":1064},[1050,3641,3116],{"class":1162},[1050,3643,1138],{"class":1064},[1050,3645,3646],{"class":1152},"authors_writing_django",[1050,3648,1233],{"class":1064},[1050,3650,3651],{"class":1052,"line":1420},[1050,3652,1122],{"emptyLinePlaceholder":1121},[1050,3654,3655],{"class":1052,"line":1426},[1050,3656,3657],{"class":1128},"# Complex relationship queries\n",[1050,3659,3660],{"class":1052,"line":1459},[1050,3661,3662],{"class":1128},"# Authors who have posts in multiple categories\n",[1050,3664,3665,3668,3670,3672,3674,3676,3678,3680],{"class":1052,"line":1482},[1050,3666,3667],{"class":1060},"multi_category_authors ",[1050,3669,1138],{"class":1064},[1050,3671,3074],{"class":1060},[1050,3673,1065],{"class":1064},[1050,3675,1147],{"class":1146},[1050,3677,1065],{"class":1064},[1050,3679,1153],{"class":1152},[1050,3681,1156],{"class":1064},[1050,3683,3684,3687,3689,3691,3694],{"class":1052,"line":1487},[1050,3685,3686],{"class":1162},"    posts__category__name",[1050,3688,1138],{"class":1064},[1050,3690,1169],{"class":1168},[1050,3692,3693],{"class":1172},"Programming",[1050,3695,3696],{"class":1168},"'\n",[1050,3698,3699,3701,3703],{"class":1052,"line":1493},[1050,3700,3564],{"class":1064},[1050,3702,1153],{"class":1152},[1050,3704,1156],{"class":1064},[1050,3706,3707,3709,3711,3713,3716],{"class":1052,"line":1539},[1050,3708,3686],{"class":1162},[1050,3710,1138],{"class":1064},[1050,3712,1169],{"class":1168},[1050,3714,3715],{"class":1172},"Web Development",[1050,3717,3696],{"class":1168},[1050,3719,3720,3722,3725],{"class":1052,"line":1584},[1050,3721,3564],{"class":1064},[1050,3723,3724],{"class":1152},"distinct",[1050,3726,2576],{"class":1064},[1050,3728,3729],{"class":1052,"line":1623},[1050,3730,1122],{"emptyLinePlaceholder":1121},[1050,3732,3733],{"class":1052,"line":1628},[1050,3734,3735],{"class":1128},"# Posts by prolific authors (more than 10 posts)\n",[1050,3737,3738,3740,3742,3744,3746,3748,3750,3752],{"class":1052,"line":1662},[1050,3739,1057],{"class":1056},[1050,3741,1061],{"class":1060},[1050,3743,1065],{"class":1064},[1050,3745,1068],{"class":1060},[1050,3747,1065],{"class":1064},[1050,3749,1073],{"class":1060},[1050,3751,1076],{"class":1056},[1050,3753,3754],{"class":1060}," Count\n",[1050,3756,3757,3760,3762,3764,3766,3768,3770,3773],{"class":1052,"line":1667},[1050,3758,3759],{"class":1060},"prolific_authors ",[1050,3761,1138],{"class":1064},[1050,3763,3074],{"class":1060},[1050,3765,1065],{"class":1064},[1050,3767,1147],{"class":1146},[1050,3769,1065],{"class":1064},[1050,3771,3772],{"class":1152},"annotate",[1050,3774,1156],{"class":1064},[1050,3776,3777,3780,3782,3785,3787,3789,3792,3794],{"class":1052,"line":1673},[1050,3778,3779],{"class":1162},"    post_count",[1050,3781,1138],{"class":1064},[1050,3783,3784],{"class":1152},"Count",[1050,3786,1221],{"class":1064},[1050,3788,1169],{"class":1168},[1050,3790,3791],{"class":1172},"posts",[1050,3793,1169],{"class":1168},[1050,3795,1233],{"class":1064},[1050,3797,3798,3800,3802,3804,3807,3809,3812],{"class":1052,"line":1692},[1050,3799,3564],{"class":1064},[1050,3801,1153],{"class":1152},[1050,3803,1221],{"class":1064},[1050,3805,3806],{"class":1162},"post_count__gt",[1050,3808,1138],{"class":1064},[1050,3810,3811],{"class":1229},"10",[1050,3813,1233],{"class":1064},[1050,3815,3816],{"class":1052,"line":1718},[1050,3817,1122],{"emptyLinePlaceholder":1121},[1050,3819,3820,3822,3824,3826,3828,3830,3832,3834,3836,3838,3840,3843],{"class":1052,"line":1766},[1050,3821,1135],{"class":1060},[1050,3823,1138],{"class":1064},[1050,3825,1141],{"class":1060},[1050,3827,1065],{"class":1064},[1050,3829,1147],{"class":1146},[1050,3831,1065],{"class":1064},[1050,3833,1153],{"class":1152},[1050,3835,1221],{"class":1064},[1050,3837,3116],{"class":1162},[1050,3839,1138],{"class":1064},[1050,3841,3842],{"class":1152},"prolific_authors",[1050,3844,1233],{"class":1064},[1030,3846,3848],{"id":3847},"ordering-and-sorting","Ordering and Sorting",[1035,3850,3852],{"id":3851},"basic-ordering","Basic Ordering",[1040,3854,3856],{"className":1042,"code":3855,"language":1044,"meta":1045,"style":1045},"# Single field ordering\nposts = Post.objects.order_by('created_at')          # Ascending\nposts = Post.objects.order_by('-created_at')         # Descending\n\n# Multiple field ordering\nposts = Post.objects.order_by('-is_featured', '-created_at', 'title')\n\n# Ordering by related fields\nposts = Post.objects.order_by('author__name', '-created_at')\nposts = Post.objects.order_by('category__name', 'author__last_name')\n\n# Random ordering\nposts = Post.objects.order_by('?')\n\n# Clear existing ordering\nposts = Post.objects.order_by('created_at').order_by()  # Removes ordering\n",[1047,3857,3858,3863,3894,3924,3928,3933,3977,3981,3986,4020,4056,4060,4065,4092,4096,4101],{"__ignoreMap":1045},[1050,3859,3860],{"class":1052,"line":1053},[1050,3861,3862],{"class":1128},"# Single field ordering\n",[1050,3864,3865,3867,3869,3871,3873,3875,3877,3880,3882,3884,3887,3889,3891],{"class":1052,"line":1088},[1050,3866,1135],{"class":1060},[1050,3868,1138],{"class":1064},[1050,3870,1141],{"class":1060},[1050,3872,1065],{"class":1064},[1050,3874,1147],{"class":1146},[1050,3876,1065],{"class":1064},[1050,3878,3879],{"class":1152},"order_by",[1050,3881,1221],{"class":1064},[1050,3883,1169],{"class":1168},[1050,3885,3886],{"class":1172},"created_at",[1050,3888,1169],{"class":1168},[1050,3890,1282],{"class":1064},[1050,3892,3893],{"class":1128},"          # Ascending\n",[1050,3895,3896,3898,3900,3902,3904,3906,3908,3910,3912,3914,3917,3919,3921],{"class":1052,"line":1105},[1050,3897,1135],{"class":1060},[1050,3899,1138],{"class":1064},[1050,3901,1141],{"class":1060},[1050,3903,1065],{"class":1064},[1050,3905,1147],{"class":1146},[1050,3907,1065],{"class":1064},[1050,3909,3879],{"class":1152},[1050,3911,1221],{"class":1064},[1050,3913,1169],{"class":1168},[1050,3915,3916],{"class":1172},"-created_at",[1050,3918,1169],{"class":1168},[1050,3920,1282],{"class":1064},[1050,3922,3923],{"class":1128},"         # Descending\n",[1050,3925,3926],{"class":1052,"line":1118},[1050,3927,1122],{"emptyLinePlaceholder":1121},[1050,3929,3930],{"class":1052,"line":1125},[1050,3931,3932],{"class":1128},"# Multiple field ordering\n",[1050,3934,3935,3937,3939,3941,3943,3945,3947,3949,3951,3953,3956,3958,3960,3962,3964,3966,3968,3970,3973,3975],{"class":1052,"line":1132},[1050,3936,1135],{"class":1060},[1050,3938,1138],{"class":1064},[1050,3940,1141],{"class":1060},[1050,3942,1065],{"class":1064},[1050,3944,1147],{"class":1146},[1050,3946,1065],{"class":1064},[1050,3948,3879],{"class":1152},[1050,3950,1221],{"class":1064},[1050,3952,1169],{"class":1168},[1050,3954,3955],{"class":1172},"-is_featured",[1050,3957,1169],{"class":1168},[1050,3959,1082],{"class":1064},[1050,3961,3008],{"class":1168},[1050,3963,3916],{"class":1172},[1050,3965,1169],{"class":1168},[1050,3967,1082],{"class":1064},[1050,3969,3008],{"class":1168},[1050,3971,3972],{"class":1172},"title",[1050,3974,1169],{"class":1168},[1050,3976,1233],{"class":1064},[1050,3978,3979],{"class":1052,"line":1159},[1050,3980,1122],{"emptyLinePlaceholder":1121},[1050,3982,3983],{"class":1052,"line":1181},[1050,3984,3985],{"class":1128},"# Ordering by related fields\n",[1050,3987,3988,3990,3992,3994,3996,3998,4000,4002,4004,4006,4008,4010,4012,4014,4016,4018],{"class":1052,"line":1195},[1050,3989,1135],{"class":1060},[1050,3991,1138],{"class":1064},[1050,3993,1141],{"class":1060},[1050,3995,1065],{"class":1064},[1050,3997,1147],{"class":1146},[1050,3999,1065],{"class":1064},[1050,4001,3879],{"class":1152},[1050,4003,1221],{"class":1064},[1050,4005,1169],{"class":1168},[1050,4007,3296],{"class":1172},[1050,4009,1169],{"class":1168},[1050,4011,1082],{"class":1064},[1050,4013,3008],{"class":1168},[1050,4015,3916],{"class":1172},[1050,4017,1169],{"class":1168},[1050,4019,1233],{"class":1064},[1050,4021,4022,4024,4026,4028,4030,4032,4034,4036,4038,4040,4043,4045,4047,4049,4052,4054],{"class":1052,"line":1236},[1050,4023,1135],{"class":1060},[1050,4025,1138],{"class":1064},[1050,4027,1141],{"class":1060},[1050,4029,1065],{"class":1064},[1050,4031,1147],{"class":1146},[1050,4033,1065],{"class":1064},[1050,4035,3879],{"class":1152},[1050,4037,1221],{"class":1064},[1050,4039,1169],{"class":1168},[1050,4041,4042],{"class":1172},"category__name",[1050,4044,1169],{"class":1168},[1050,4046,1082],{"class":1064},[1050,4048,3008],{"class":1168},[1050,4050,4051],{"class":1172},"author__last_name",[1050,4053,1169],{"class":1168},[1050,4055,1233],{"class":1064},[1050,4057,4058],{"class":1052,"line":1241},[1050,4059,1122],{"emptyLinePlaceholder":1121},[1050,4061,4062],{"class":1052,"line":1246},[1050,4063,4064],{"class":1128},"# Random ordering\n",[1050,4066,4067,4069,4071,4073,4075,4077,4079,4081,4083,4085,4088,4090],{"class":1052,"line":1252},[1050,4068,1135],{"class":1060},[1050,4070,1138],{"class":1064},[1050,4072,1141],{"class":1060},[1050,4074,1065],{"class":1064},[1050,4076,1147],{"class":1146},[1050,4078,1065],{"class":1064},[1050,4080,3879],{"class":1152},[1050,4082,1221],{"class":1064},[1050,4084,1169],{"class":1168},[1050,4086,4087],{"class":1172},"?",[1050,4089,1169],{"class":1168},[1050,4091,1233],{"class":1064},[1050,4093,4094],{"class":1052,"line":1288},[1050,4095,1122],{"emptyLinePlaceholder":1121},[1050,4097,4098],{"class":1052,"line":1309},[1050,4099,4100],{"class":1128},"# Clear existing ordering\n",[1050,4102,4103,4105,4107,4109,4111,4113,4115,4117,4119,4121,4123,4125,4127,4129,4131],{"class":1052,"line":1346},[1050,4104,1135],{"class":1060},[1050,4106,1138],{"class":1064},[1050,4108,1141],{"class":1060},[1050,4110,1065],{"class":1064},[1050,4112,1147],{"class":1146},[1050,4114,1065],{"class":1064},[1050,4116,3879],{"class":1152},[1050,4118,1221],{"class":1064},[1050,4120,1169],{"class":1168},[1050,4122,3886],{"class":1172},[1050,4124,1169],{"class":1168},[1050,4126,3564],{"class":1064},[1050,4128,3879],{"class":1152},[1050,4130,1211],{"class":1064},[1050,4132,4133],{"class":1128},"  # Removes ordering\n",[1035,4135,4137],{"id":4136},"advanced-ordering-techniques","Advanced Ordering Techniques",[1040,4139,4141],{"className":1042,"code":4140,"language":1044,"meta":1045,"style":1045},"from django.db.models import F, Case, When, Value, IntegerField\nfrom django.db.models.functions import Lower, Length\n\n# Ordering by computed values\nposts = Post.objects.annotate(\n    engagement_score=F('view_count') + F('like_count') * 2\n).order_by('-engagement_score')\n\n# Case-insensitive ordering\nauthors = Author.objects.order_by(Lower('name'))\n\n# Ordering by field length\nposts = Post.objects.order_by(Length('title'))\n\n# Custom ordering with Case/When\nposts = Post.objects.annotate(\n    status_order=Case(\n        When(status='featured', then=Value(1)),\n        When(status='published', then=Value(2)),\n        When(status='draft', then=Value(3)),\n        default=Value(4),\n        output_field=IntegerField()\n    )\n).order_by('status_order', '-created_at')\n\n# Null values ordering (database-dependent)\nposts = Post.objects.order_by(F('published_at').asc(nulls_last=True))\nposts = Post.objects.order_by(F('published_at').desc(nulls_first=True))\n\n# Ordering by aggregated values\nfrom django.db.models import Avg, Count, Max\n\nauthors = Author.objects.annotate(\n    avg_views=Avg('posts__view_count'),\n    post_count=Count('posts'),\n    latest_post=Max('posts__created_at')\n).order_by('-avg_views', '-post_count')\n\n# Ordering by related field aggregation\ncategories = Category.objects.annotate(\n    total_views=Count('posts__view_count'),\n    post_count=Count('posts')\n).order_by('-total_views')\n",[1047,4142,4143,4182,4212,4216,4221,4239,4282,4299,4303,4308,4340,4344,4349,4380,4384,4389,4407,4419,4454,4485,4516,4532,4544,4549,4574,4578,4583,4628,4672,4676,4681,4710,4714,4732,4753,4771,4792,4818,4822,4827,4845,4864,4882],{"__ignoreMap":1045},[1050,4144,4145,4147,4149,4151,4153,4155,4157,4159,4162,4164,4167,4169,4172,4174,4177,4179],{"class":1052,"line":1053},[1050,4146,1057],{"class":1056},[1050,4148,1061],{"class":1060},[1050,4150,1065],{"class":1064},[1050,4152,1068],{"class":1060},[1050,4154,1065],{"class":1064},[1050,4156,1073],{"class":1060},[1050,4158,1076],{"class":1056},[1050,4160,4161],{"class":1060}," F",[1050,4163,1082],{"class":1064},[1050,4165,4166],{"class":1060}," Case",[1050,4168,1082],{"class":1064},[1050,4170,4171],{"class":1060}," When",[1050,4173,1082],{"class":1064},[1050,4175,4176],{"class":1060}," Value",[1050,4178,1082],{"class":1064},[1050,4180,4181],{"class":1060}," IntegerField\n",[1050,4183,4184,4186,4188,4190,4192,4194,4197,4199,4202,4204,4207,4209],{"class":1052,"line":1088},[1050,4185,1057],{"class":1056},[1050,4187,1061],{"class":1060},[1050,4189,1065],{"class":1064},[1050,4191,1068],{"class":1060},[1050,4193,1065],{"class":1064},[1050,4195,4196],{"class":1060},"models",[1050,4198,1065],{"class":1064},[1050,4200,4201],{"class":1060},"functions ",[1050,4203,1076],{"class":1056},[1050,4205,4206],{"class":1060}," Lower",[1050,4208,1082],{"class":1064},[1050,4210,4211],{"class":1060}," Length\n",[1050,4213,4214],{"class":1052,"line":1105},[1050,4215,1122],{"emptyLinePlaceholder":1121},[1050,4217,4218],{"class":1052,"line":1118},[1050,4219,4220],{"class":1128},"# Ordering by computed values\n",[1050,4222,4223,4225,4227,4229,4231,4233,4235,4237],{"class":1052,"line":1125},[1050,4224,1135],{"class":1060},[1050,4226,1138],{"class":1064},[1050,4228,1141],{"class":1060},[1050,4230,1065],{"class":1064},[1050,4232,1147],{"class":1146},[1050,4234,1065],{"class":1064},[1050,4236,3772],{"class":1152},[1050,4238,1156],{"class":1064},[1050,4240,4241,4244,4246,4249,4251,4253,4256,4258,4260,4263,4265,4267,4269,4272,4274,4276,4279],{"class":1052,"line":1132},[1050,4242,4243],{"class":1162},"    engagement_score",[1050,4245,1138],{"class":1064},[1050,4247,4248],{"class":1152},"F",[1050,4250,1221],{"class":1064},[1050,4252,1169],{"class":1168},[1050,4254,4255],{"class":1172},"view_count",[1050,4257,1169],{"class":1168},[1050,4259,1282],{"class":1064},[1050,4261,4262],{"class":1214}," +",[1050,4264,4161],{"class":1152},[1050,4266,1221],{"class":1064},[1050,4268,1169],{"class":1168},[1050,4270,4271],{"class":1172},"like_count",[1050,4273,1169],{"class":1168},[1050,4275,1282],{"class":1064},[1050,4277,4278],{"class":1214}," *",[1050,4280,4281],{"class":1229}," 2\n",[1050,4283,4284,4286,4288,4290,4292,4295,4297],{"class":1052,"line":1159},[1050,4285,3564],{"class":1064},[1050,4287,3879],{"class":1152},[1050,4289,1221],{"class":1064},[1050,4291,1169],{"class":1168},[1050,4293,4294],{"class":1172},"-engagement_score",[1050,4296,1169],{"class":1168},[1050,4298,1233],{"class":1064},[1050,4300,4301],{"class":1052,"line":1181},[1050,4302,1122],{"emptyLinePlaceholder":1121},[1050,4304,4305],{"class":1052,"line":1195},[1050,4306,4307],{"class":1128},"# Case-insensitive ordering\n",[1050,4309,4310,4312,4314,4316,4318,4320,4322,4324,4326,4329,4331,4333,4336,4338],{"class":1052,"line":1236},[1050,4311,3384],{"class":1060},[1050,4313,1138],{"class":1064},[1050,4315,3074],{"class":1060},[1050,4317,1065],{"class":1064},[1050,4319,1147],{"class":1146},[1050,4321,1065],{"class":1064},[1050,4323,3879],{"class":1152},[1050,4325,1221],{"class":1064},[1050,4327,4328],{"class":1152},"Lower",[1050,4330,1221],{"class":1064},[1050,4332,1169],{"class":1168},[1050,4334,4335],{"class":1172},"name",[1050,4337,1169],{"class":1168},[1050,4339,1343],{"class":1064},[1050,4341,4342],{"class":1052,"line":1241},[1050,4343,1122],{"emptyLinePlaceholder":1121},[1050,4345,4346],{"class":1052,"line":1246},[1050,4347,4348],{"class":1128},"# Ordering by field length\n",[1050,4350,4351,4353,4355,4357,4359,4361,4363,4365,4367,4370,4372,4374,4376,4378],{"class":1052,"line":1252},[1050,4352,1135],{"class":1060},[1050,4354,1138],{"class":1064},[1050,4356,1141],{"class":1060},[1050,4358,1065],{"class":1064},[1050,4360,1147],{"class":1146},[1050,4362,1065],{"class":1064},[1050,4364,3879],{"class":1152},[1050,4366,1221],{"class":1064},[1050,4368,4369],{"class":1152},"Length",[1050,4371,1221],{"class":1064},[1050,4373,1169],{"class":1168},[1050,4375,3972],{"class":1172},[1050,4377,1169],{"class":1168},[1050,4379,1343],{"class":1064},[1050,4381,4382],{"class":1052,"line":1288},[1050,4383,1122],{"emptyLinePlaceholder":1121},[1050,4385,4386],{"class":1052,"line":1309},[1050,4387,4388],{"class":1128},"# Custom ordering with Case/When\n",[1050,4390,4391,4393,4395,4397,4399,4401,4403,4405],{"class":1052,"line":1346},[1050,4392,1135],{"class":1060},[1050,4394,1138],{"class":1064},[1050,4396,1141],{"class":1060},[1050,4398,1065],{"class":1064},[1050,4400,1147],{"class":1146},[1050,4402,1065],{"class":1064},[1050,4404,3772],{"class":1152},[1050,4406,1156],{"class":1064},[1050,4408,4409,4412,4414,4417],{"class":1052,"line":1351},[1050,4410,4411],{"class":1162},"    status_order",[1050,4413,1138],{"class":1064},[1050,4415,4416],{"class":1152},"Case",[1050,4418,1156],{"class":1064},[1050,4420,4421,4424,4426,4428,4430,4432,4435,4437,4439,4442,4444,4447,4449,4451],{"class":1052,"line":1357},[1050,4422,4423],{"class":1152},"        When",[1050,4425,1221],{"class":1064},[1050,4427,1271],{"class":1162},[1050,4429,1138],{"class":1064},[1050,4431,1169],{"class":1168},[1050,4433,4434],{"class":1172},"featured",[1050,4436,1169],{"class":1168},[1050,4438,1082],{"class":1064},[1050,4440,4441],{"class":1162}," then",[1050,4443,1138],{"class":1064},[1050,4445,4446],{"class":1152},"Value",[1050,4448,1221],{"class":1064},[1050,4450,2431],{"class":1229},[1050,4452,4453],{"class":1064},")),\n",[1050,4455,4456,4458,4460,4462,4464,4466,4468,4470,4472,4474,4476,4478,4480,4483],{"class":1052,"line":1392},[1050,4457,4423],{"class":1152},[1050,4459,1221],{"class":1064},[1050,4461,1271],{"class":1162},[1050,4463,1138],{"class":1064},[1050,4465,1169],{"class":1168},[1050,4467,1173],{"class":1172},[1050,4469,1169],{"class":1168},[1050,4471,1082],{"class":1064},[1050,4473,4441],{"class":1162},[1050,4475,1138],{"class":1064},[1050,4477,4446],{"class":1152},[1050,4479,1221],{"class":1064},[1050,4481,4482],{"class":1229},"2",[1050,4484,4453],{"class":1064},[1050,4486,4487,4489,4491,4493,4495,4497,4499,4501,4503,4505,4507,4509,4511,4514],{"class":1052,"line":1415},[1050,4488,4423],{"class":1152},[1050,4490,1221],{"class":1064},[1050,4492,1271],{"class":1162},[1050,4494,1138],{"class":1064},[1050,4496,1169],{"class":1168},[1050,4498,1383],{"class":1172},[1050,4500,1169],{"class":1168},[1050,4502,1082],{"class":1064},[1050,4504,4441],{"class":1162},[1050,4506,1138],{"class":1064},[1050,4508,4446],{"class":1152},[1050,4510,1221],{"class":1064},[1050,4512,4513],{"class":1229},"3",[1050,4515,4453],{"class":1064},[1050,4517,4518,4521,4523,4525,4527,4529],{"class":1052,"line":1420},[1050,4519,4520],{"class":1162},"        default",[1050,4522,1138],{"class":1064},[1050,4524,4446],{"class":1152},[1050,4526,1221],{"class":1064},[1050,4528,2462],{"class":1229},[1050,4530,4531],{"class":1064},"),\n",[1050,4533,4534,4537,4539,4542],{"class":1052,"line":1426},[1050,4535,4536],{"class":1162},"        output_field",[1050,4538,1138],{"class":1064},[1050,4540,4541],{"class":1152},"IntegerField",[1050,4543,2576],{"class":1064},[1050,4545,4546],{"class":1052,"line":1459},[1050,4547,4548],{"class":1064},"    )\n",[1050,4550,4551,4553,4555,4557,4559,4562,4564,4566,4568,4570,4572],{"class":1052,"line":1482},[1050,4552,3564],{"class":1064},[1050,4554,3879],{"class":1152},[1050,4556,1221],{"class":1064},[1050,4558,1169],{"class":1168},[1050,4560,4561],{"class":1172},"status_order",[1050,4563,1169],{"class":1168},[1050,4565,1082],{"class":1064},[1050,4567,3008],{"class":1168},[1050,4569,3916],{"class":1172},[1050,4571,1169],{"class":1168},[1050,4573,1233],{"class":1064},[1050,4575,4576],{"class":1052,"line":1487},[1050,4577,1122],{"emptyLinePlaceholder":1121},[1050,4579,4580],{"class":1052,"line":1493},[1050,4581,4582],{"class":1128},"# Null values ordering (database-dependent)\n",[1050,4584,4585,4587,4589,4591,4593,4595,4597,4599,4601,4603,4605,4607,4610,4612,4614,4617,4619,4622,4624,4626],{"class":1052,"line":1539},[1050,4586,1135],{"class":1060},[1050,4588,1138],{"class":1064},[1050,4590,1141],{"class":1060},[1050,4592,1065],{"class":1064},[1050,4594,1147],{"class":1146},[1050,4596,1065],{"class":1064},[1050,4598,3879],{"class":1152},[1050,4600,1221],{"class":1064},[1050,4602,4248],{"class":1152},[1050,4604,1221],{"class":1064},[1050,4606,1169],{"class":1168},[1050,4608,4609],{"class":1172},"published_at",[1050,4611,1169],{"class":1168},[1050,4613,3564],{"class":1064},[1050,4615,4616],{"class":1152},"asc",[1050,4618,1221],{"class":1064},[1050,4620,4621],{"class":1162},"nulls_last",[1050,4623,1138],{"class":1064},[1050,4625,1190],{"class":1189},[1050,4627,1343],{"class":1064},[1050,4629,4630,4632,4634,4636,4638,4640,4642,4644,4646,4648,4650,4652,4654,4656,4658,4661,4663,4666,4668,4670],{"class":1052,"line":1584},[1050,4631,1135],{"class":1060},[1050,4633,1138],{"class":1064},[1050,4635,1141],{"class":1060},[1050,4637,1065],{"class":1064},[1050,4639,1147],{"class":1146},[1050,4641,1065],{"class":1064},[1050,4643,3879],{"class":1152},[1050,4645,1221],{"class":1064},[1050,4647,4248],{"class":1152},[1050,4649,1221],{"class":1064},[1050,4651,1169],{"class":1168},[1050,4653,4609],{"class":1172},[1050,4655,1169],{"class":1168},[1050,4657,3564],{"class":1064},[1050,4659,4660],{"class":1152},"desc",[1050,4662,1221],{"class":1064},[1050,4664,4665],{"class":1162},"nulls_first",[1050,4667,1138],{"class":1064},[1050,4669,1190],{"class":1189},[1050,4671,1343],{"class":1064},[1050,4673,4674],{"class":1052,"line":1623},[1050,4675,1122],{"emptyLinePlaceholder":1121},[1050,4677,4678],{"class":1052,"line":1628},[1050,4679,4680],{"class":1128},"# Ordering by aggregated values\n",[1050,4682,4683,4685,4687,4689,4691,4693,4695,4697,4700,4702,4705,4707],{"class":1052,"line":1662},[1050,4684,1057],{"class":1056},[1050,4686,1061],{"class":1060},[1050,4688,1065],{"class":1064},[1050,4690,1068],{"class":1060},[1050,4692,1065],{"class":1064},[1050,4694,1073],{"class":1060},[1050,4696,1076],{"class":1056},[1050,4698,4699],{"class":1060}," Avg",[1050,4701,1082],{"class":1064},[1050,4703,4704],{"class":1060}," Count",[1050,4706,1082],{"class":1064},[1050,4708,4709],{"class":1060}," Max\n",[1050,4711,4712],{"class":1052,"line":1667},[1050,4713,1122],{"emptyLinePlaceholder":1121},[1050,4715,4716,4718,4720,4722,4724,4726,4728,4730],{"class":1052,"line":1673},[1050,4717,3384],{"class":1060},[1050,4719,1138],{"class":1064},[1050,4721,3074],{"class":1060},[1050,4723,1065],{"class":1064},[1050,4725,1147],{"class":1146},[1050,4727,1065],{"class":1064},[1050,4729,3772],{"class":1152},[1050,4731,1156],{"class":1064},[1050,4733,4734,4737,4739,4742,4744,4746,4749,4751],{"class":1052,"line":1692},[1050,4735,4736],{"class":1162},"    avg_views",[1050,4738,1138],{"class":1064},[1050,4740,4741],{"class":1152},"Avg",[1050,4743,1221],{"class":1064},[1050,4745,1169],{"class":1168},[1050,4747,4748],{"class":1172},"posts__view_count",[1050,4750,1169],{"class":1168},[1050,4752,4531],{"class":1064},[1050,4754,4755,4757,4759,4761,4763,4765,4767,4769],{"class":1052,"line":1718},[1050,4756,3779],{"class":1162},[1050,4758,1138],{"class":1064},[1050,4760,3784],{"class":1152},[1050,4762,1221],{"class":1064},[1050,4764,1169],{"class":1168},[1050,4766,3791],{"class":1172},[1050,4768,1169],{"class":1168},[1050,4770,4531],{"class":1064},[1050,4772,4773,4776,4778,4781,4783,4785,4788,4790],{"class":1052,"line":1766},[1050,4774,4775],{"class":1162},"    latest_post",[1050,4777,1138],{"class":1064},[1050,4779,4780],{"class":1152},"Max",[1050,4782,1221],{"class":1064},[1050,4784,1169],{"class":1168},[1050,4786,4787],{"class":1172},"posts__created_at",[1050,4789,1169],{"class":1168},[1050,4791,1233],{"class":1064},[1050,4793,4794,4796,4798,4800,4802,4805,4807,4809,4811,4814,4816],{"class":1052,"line":1789},[1050,4795,3564],{"class":1064},[1050,4797,3879],{"class":1152},[1050,4799,1221],{"class":1064},[1050,4801,1169],{"class":1168},[1050,4803,4804],{"class":1172},"-avg_views",[1050,4806,1169],{"class":1168},[1050,4808,1082],{"class":1064},[1050,4810,3008],{"class":1168},[1050,4812,4813],{"class":1172},"-post_count",[1050,4815,1169],{"class":1168},[1050,4817,1233],{"class":1064},[1050,4819,4820],{"class":1052,"line":2642},[1050,4821,1122],{"emptyLinePlaceholder":1121},[1050,4823,4824],{"class":1052,"line":2654},[1050,4825,4826],{"class":1128},"# Ordering by related field aggregation\n",[1050,4828,4829,4831,4833,4835,4837,4839,4841,4843],{"class":1052,"line":2677},[1050,4830,2992],{"class":1060},[1050,4832,1138],{"class":1064},[1050,4834,3420],{"class":1060},[1050,4836,1065],{"class":1064},[1050,4838,1147],{"class":1146},[1050,4840,1065],{"class":1064},[1050,4842,3772],{"class":1152},[1050,4844,1156],{"class":1064},[1050,4846,4847,4850,4852,4854,4856,4858,4860,4862],{"class":1052,"line":2706},[1050,4848,4849],{"class":1162},"    total_views",[1050,4851,1138],{"class":1064},[1050,4853,3784],{"class":1152},[1050,4855,1221],{"class":1064},[1050,4857,1169],{"class":1168},[1050,4859,4748],{"class":1172},[1050,4861,1169],{"class":1168},[1050,4863,4531],{"class":1064},[1050,4865,4866,4868,4870,4872,4874,4876,4878,4880],{"class":1052,"line":2711},[1050,4867,3779],{"class":1162},[1050,4869,1138],{"class":1064},[1050,4871,3784],{"class":1152},[1050,4873,1221],{"class":1064},[1050,4875,1169],{"class":1168},[1050,4877,3791],{"class":1172},[1050,4879,1169],{"class":1168},[1050,4881,1233],{"class":1064},[1050,4883,4884,4886,4888,4890,4892,4895,4897],{"class":1052,"line":2717},[1050,4885,3564],{"class":1064},[1050,4887,3879],{"class":1152},[1050,4889,1221],{"class":1064},[1050,4891,1169],{"class":1168},[1050,4893,4894],{"class":1172},"-total_views",[1050,4896,1169],{"class":1168},[1050,4898,1233],{"class":1064},[1035,4900,4902],{"id":4901},"dynamic-ordering","Dynamic Ordering",[1040,4904,4906],{"className":1042,"code":4905,"language":1044,"meta":1045,"style":1045},"def get_posts(sort_by='created_at', order='desc'):\n    \"\"\"Dynamic post ordering based on parameters\"\"\"\n    \n    valid_sort_fields = {\n        'created_at': 'created_at',\n        'title': 'title',\n        'author': 'author__name',\n        'category': 'category__name',\n        'views': 'view_count',\n        'likes': 'like_count'\n    }\n    \n    sort_field = valid_sort_fields.get(sort_by, 'created_at')\n    \n    if order == 'desc':\n        sort_field = f'-{sort_field}'\n    \n    return Post.objects.filter(status='published').order_by(sort_field)\n\n# Usage\nrecent_posts = get_posts('created_at', 'desc')\npopular_posts = get_posts('views', 'desc')\nalphabetical_posts = get_posts('title', 'asc')\n\n# Advanced dynamic ordering with multiple criteria\ndef get_sorted_posts(primary_sort=None, secondary_sort=None, **filters):\n    \"\"\"Flexible post sorting with multiple criteria\"\"\"\n    \n    queryset = Post.objects.filter(**filters)\n    \n    order_fields = []\n    \n    if primary_sort:\n        order_fields.append(primary_sort)\n    \n    if secondary_sort:\n        order_fields.append(secondary_sort)\n    \n    # Default ordering\n    if not order_fields:\n        order_fields = ['-created_at']\n    \n    return queryset.order_by(*order_fields)\n\n# Usage\nposts = get_sorted_posts(\n    primary_sort='-is_featured',\n    secondary_sort='-view_count',\n    status='published'\n)\n",[1047,4907,4908,4947,4960,4965,4975,4995,5013,5032,5051,5070,5087,5092,5096,5125,5129,5149,5174,5178,5215,5219,5224,5251,5278,5305,5309,5314,5350,5359,5363,5389,5393,5403,5407,5416,5432,5436,5444,5459,5463,5468,5480,5497,5501,5522,5526,5530,5540,5555,5571,5583],{"__ignoreMap":1045},[1050,4909,4910,4913,4917,4919,4923,4925,4927,4929,4931,4933,4936,4938,4940,4942,4944],{"class":1052,"line":1053},[1050,4911,4912],{"class":3161},"def",[1050,4914,4916],{"class":4915},"sljsM"," get_posts",[1050,4918,1221],{"class":1064},[1050,4920,4922],{"class":4921},"sCyAa","sort_by",[1050,4924,1138],{"class":1214},[1050,4926,1169],{"class":1168},[1050,4928,3886],{"class":1172},[1050,4930,1169],{"class":1168},[1050,4932,1082],{"class":1064},[1050,4934,4935],{"class":4921}," order",[1050,4937,1138],{"class":1214},[1050,4939,1169],{"class":1168},[1050,4941,4660],{"class":1172},[1050,4943,1169],{"class":1168},[1050,4945,4946],{"class":1064},"):\n",[1050,4948,4949,4953,4957],{"class":1052,"line":1088},[1050,4950,4952],{"class":4951},"sm7ve","    \"\"\"",[1050,4954,4956],{"class":4955},"sVyVU","Dynamic post ordering based on parameters",[1050,4958,4959],{"class":4951},"\"\"\"\n",[1050,4961,4962],{"class":1052,"line":1105},[1050,4963,4964],{"class":1060},"    \n",[1050,4966,4967,4970,4972],{"class":1052,"line":1118},[1050,4968,4969],{"class":1060},"    valid_sort_fields ",[1050,4971,1138],{"class":1064},[1050,4973,4974],{"class":1064}," {\n",[1050,4976,4977,4980,4982,4984,4987,4989,4991,4993],{"class":1052,"line":1125},[1050,4978,4979],{"class":1168},"        '",[1050,4981,3886],{"class":1172},[1050,4983,1169],{"class":1168},[1050,4985,4986],{"class":1064},":",[1050,4988,3008],{"class":1168},[1050,4990,3886],{"class":1172},[1050,4992,1169],{"class":1168},[1050,4994,1178],{"class":1064},[1050,4996,4997,4999,5001,5003,5005,5007,5009,5011],{"class":1052,"line":1132},[1050,4998,4979],{"class":1168},[1050,5000,3972],{"class":1172},[1050,5002,1169],{"class":1168},[1050,5004,4986],{"class":1064},[1050,5006,3008],{"class":1168},[1050,5008,3972],{"class":1172},[1050,5010,1169],{"class":1168},[1050,5012,1178],{"class":1064},[1050,5014,5015,5017,5020,5022,5024,5026,5028,5030],{"class":1052,"line":1159},[1050,5016,4979],{"class":1168},[1050,5018,5019],{"class":1172},"author",[1050,5021,1169],{"class":1168},[1050,5023,4986],{"class":1064},[1050,5025,3008],{"class":1168},[1050,5027,3296],{"class":1172},[1050,5029,1169],{"class":1168},[1050,5031,1178],{"class":1064},[1050,5033,5034,5036,5039,5041,5043,5045,5047,5049],{"class":1052,"line":1181},[1050,5035,4979],{"class":1168},[1050,5037,5038],{"class":1172},"category",[1050,5040,1169],{"class":1168},[1050,5042,4986],{"class":1064},[1050,5044,3008],{"class":1168},[1050,5046,4042],{"class":1172},[1050,5048,1169],{"class":1168},[1050,5050,1178],{"class":1064},[1050,5052,5053,5055,5058,5060,5062,5064,5066,5068],{"class":1052,"line":1195},[1050,5054,4979],{"class":1168},[1050,5056,5057],{"class":1172},"views",[1050,5059,1169],{"class":1168},[1050,5061,4986],{"class":1064},[1050,5063,3008],{"class":1168},[1050,5065,4255],{"class":1172},[1050,5067,1169],{"class":1168},[1050,5069,1178],{"class":1064},[1050,5071,5072,5074,5077,5079,5081,5083,5085],{"class":1052,"line":1236},[1050,5073,4979],{"class":1168},[1050,5075,5076],{"class":1172},"likes",[1050,5078,1169],{"class":1168},[1050,5080,4986],{"class":1064},[1050,5082,3008],{"class":1168},[1050,5084,4271],{"class":1172},[1050,5086,3696],{"class":1168},[1050,5088,5089],{"class":1052,"line":1241},[1050,5090,5091],{"class":1064},"    }\n",[1050,5093,5094],{"class":1052,"line":1246},[1050,5095,4964],{"class":1060},[1050,5097,5098,5101,5103,5106,5108,5111,5113,5115,5117,5119,5121,5123],{"class":1052,"line":1252},[1050,5099,5100],{"class":1060},"    sort_field ",[1050,5102,1138],{"class":1064},[1050,5104,5105],{"class":1060}," valid_sort_fields",[1050,5107,1065],{"class":1064},[1050,5109,5110],{"class":1152},"get",[1050,5112,1221],{"class":1064},[1050,5114,4922],{"class":1152},[1050,5116,1082],{"class":1064},[1050,5118,3008],{"class":1168},[1050,5120,3886],{"class":1172},[1050,5122,1169],{"class":1168},[1050,5124,1233],{"class":1064},[1050,5126,5127],{"class":1052,"line":1288},[1050,5128,4964],{"class":1060},[1050,5130,5131,5134,5137,5140,5142,5144,5146],{"class":1052,"line":1309},[1050,5132,5133],{"class":1056},"    if",[1050,5135,5136],{"class":1060}," order ",[1050,5138,5139],{"class":1214},"==",[1050,5141,3008],{"class":1168},[1050,5143,4660],{"class":1172},[1050,5145,1169],{"class":1168},[1050,5147,5148],{"class":1064},":\n",[1050,5150,5151,5154,5156,5159,5162,5166,5169,5172],{"class":1052,"line":1346},[1050,5152,5153],{"class":1060},"        sort_field ",[1050,5155,1138],{"class":1064},[1050,5157,5158],{"class":3161}," f",[1050,5160,5161],{"class":1172},"'-",[1050,5163,5165],{"class":5164},"s3h35","{",[1050,5167,5168],{"class":1060},"sort_field",[1050,5170,5171],{"class":5164},"}",[1050,5173,3696],{"class":1172},[1050,5175,5176],{"class":1052,"line":1351},[1050,5177,4964],{"class":1060},[1050,5179,5180,5183,5185,5187,5189,5191,5193,5195,5197,5199,5201,5203,5205,5207,5209,5211,5213],{"class":1052,"line":1357},[1050,5181,5182],{"class":1056},"    return",[1050,5184,1141],{"class":1060},[1050,5186,1065],{"class":1064},[1050,5188,1147],{"class":1146},[1050,5190,1065],{"class":1064},[1050,5192,1153],{"class":1152},[1050,5194,1221],{"class":1064},[1050,5196,1271],{"class":1162},[1050,5198,1138],{"class":1064},[1050,5200,1169],{"class":1168},[1050,5202,1173],{"class":1172},[1050,5204,1169],{"class":1168},[1050,5206,3564],{"class":1064},[1050,5208,3879],{"class":1152},[1050,5210,1221],{"class":1064},[1050,5212,5168],{"class":1152},[1050,5214,1233],{"class":1064},[1050,5216,5217],{"class":1052,"line":1392},[1050,5218,1122],{"emptyLinePlaceholder":1121},[1050,5220,5221],{"class":1052,"line":1415},[1050,5222,5223],{"class":1128},"# Usage\n",[1050,5225,5226,5229,5231,5233,5235,5237,5239,5241,5243,5245,5247,5249],{"class":1052,"line":1420},[1050,5227,5228],{"class":1060},"recent_posts ",[1050,5230,1138],{"class":1064},[1050,5232,4916],{"class":1152},[1050,5234,1221],{"class":1064},[1050,5236,1169],{"class":1168},[1050,5238,3886],{"class":1172},[1050,5240,1169],{"class":1168},[1050,5242,1082],{"class":1064},[1050,5244,3008],{"class":1168},[1050,5246,4660],{"class":1172},[1050,5248,1169],{"class":1168},[1050,5250,1233],{"class":1064},[1050,5252,5253,5256,5258,5260,5262,5264,5266,5268,5270,5272,5274,5276],{"class":1052,"line":1426},[1050,5254,5255],{"class":1060},"popular_posts ",[1050,5257,1138],{"class":1064},[1050,5259,4916],{"class":1152},[1050,5261,1221],{"class":1064},[1050,5263,1169],{"class":1168},[1050,5265,5057],{"class":1172},[1050,5267,1169],{"class":1168},[1050,5269,1082],{"class":1064},[1050,5271,3008],{"class":1168},[1050,5273,4660],{"class":1172},[1050,5275,1169],{"class":1168},[1050,5277,1233],{"class":1064},[1050,5279,5280,5283,5285,5287,5289,5291,5293,5295,5297,5299,5301,5303],{"class":1052,"line":1459},[1050,5281,5282],{"class":1060},"alphabetical_posts ",[1050,5284,1138],{"class":1064},[1050,5286,4916],{"class":1152},[1050,5288,1221],{"class":1064},[1050,5290,1169],{"class":1168},[1050,5292,3972],{"class":1172},[1050,5294,1169],{"class":1168},[1050,5296,1082],{"class":1064},[1050,5298,3008],{"class":1168},[1050,5300,4616],{"class":1172},[1050,5302,1169],{"class":1168},[1050,5304,1233],{"class":1064},[1050,5306,5307],{"class":1052,"line":1482},[1050,5308,1122],{"emptyLinePlaceholder":1121},[1050,5310,5311],{"class":1052,"line":1487},[1050,5312,5313],{"class":1128},"# Advanced dynamic ordering with multiple criteria\n",[1050,5315,5316,5318,5321,5323,5326,5328,5331,5333,5336,5338,5340,5342,5345,5348],{"class":1052,"line":1493},[1050,5317,4912],{"class":3161},[1050,5319,5320],{"class":4915}," get_sorted_posts",[1050,5322,1221],{"class":1064},[1050,5324,5325],{"class":4921},"primary_sort",[1050,5327,1138],{"class":1214},[1050,5329,5330],{"class":1189},"None",[1050,5332,1082],{"class":1064},[1050,5334,5335],{"class":4921}," secondary_sort",[1050,5337,1138],{"class":1214},[1050,5339,5330],{"class":1189},[1050,5341,1082],{"class":1064},[1050,5343,5344],{"class":1214}," **",[1050,5346,5347],{"class":4921},"filters",[1050,5349,4946],{"class":1064},[1050,5351,5352,5354,5357],{"class":1052,"line":1539},[1050,5353,4952],{"class":4951},[1050,5355,5356],{"class":4955},"Flexible post sorting with multiple criteria",[1050,5358,4959],{"class":4951},[1050,5360,5361],{"class":1052,"line":1584},[1050,5362,4964],{"class":1060},[1050,5364,5365,5368,5370,5372,5374,5376,5378,5380,5382,5385,5387],{"class":1052,"line":1623},[1050,5366,5367],{"class":1060},"    queryset ",[1050,5369,1138],{"class":1064},[1050,5371,1141],{"class":1060},[1050,5373,1065],{"class":1064},[1050,5375,1147],{"class":1146},[1050,5377,1065],{"class":1064},[1050,5379,1153],{"class":1152},[1050,5381,1221],{"class":1064},[1050,5383,5384],{"class":1214},"**",[1050,5386,5347],{"class":1152},[1050,5388,1233],{"class":1064},[1050,5390,5391],{"class":1052,"line":1628},[1050,5392,4964],{"class":1060},[1050,5394,5395,5398,5400],{"class":1052,"line":1662},[1050,5396,5397],{"class":1060},"    order_fields ",[1050,5399,1138],{"class":1064},[1050,5401,5402],{"class":1064}," []\n",[1050,5404,5405],{"class":1052,"line":1667},[1050,5406,4964],{"class":1060},[1050,5408,5409,5411,5414],{"class":1052,"line":1673},[1050,5410,5133],{"class":1056},[1050,5412,5413],{"class":1060}," primary_sort",[1050,5415,5148],{"class":1064},[1050,5417,5418,5421,5423,5426,5428,5430],{"class":1052,"line":1692},[1050,5419,5420],{"class":1060},"        order_fields",[1050,5422,1065],{"class":1064},[1050,5424,5425],{"class":1152},"append",[1050,5427,1221],{"class":1064},[1050,5429,5325],{"class":1152},[1050,5431,1233],{"class":1064},[1050,5433,5434],{"class":1052,"line":1718},[1050,5435,4964],{"class":1060},[1050,5437,5438,5440,5442],{"class":1052,"line":1766},[1050,5439,5133],{"class":1056},[1050,5441,5335],{"class":1060},[1050,5443,5148],{"class":1064},[1050,5445,5446,5448,5450,5452,5454,5457],{"class":1052,"line":1789},[1050,5447,5420],{"class":1060},[1050,5449,1065],{"class":1064},[1050,5451,5425],{"class":1152},[1050,5453,1221],{"class":1064},[1050,5455,5456],{"class":1152},"secondary_sort",[1050,5458,1233],{"class":1064},[1050,5460,5461],{"class":1052,"line":2642},[1050,5462,4964],{"class":1060},[1050,5464,5465],{"class":1052,"line":2654},[1050,5466,5467],{"class":1128},"    # Default ordering\n",[1050,5469,5470,5472,5475,5478],{"class":1052,"line":2677},[1050,5471,5133],{"class":1056},[1050,5473,5474],{"class":1214}," not",[1050,5476,5477],{"class":1060}," order_fields",[1050,5479,5148],{"class":1064},[1050,5481,5482,5485,5487,5489,5491,5493,5495],{"class":1052,"line":2706},[1050,5483,5484],{"class":1060},"        order_fields ",[1050,5486,1138],{"class":1064},[1050,5488,2927],{"class":1064},[1050,5490,1169],{"class":1168},[1050,5492,3916],{"class":1172},[1050,5494,1169],{"class":1168},[1050,5496,2952],{"class":1064},[1050,5498,5499],{"class":1052,"line":2711},[1050,5500,4964],{"class":1060},[1050,5502,5503,5505,5508,5510,5512,5514,5517,5520],{"class":1052,"line":2717},[1050,5504,5182],{"class":1056},[1050,5506,5507],{"class":1060}," queryset",[1050,5509,1065],{"class":1064},[1050,5511,3879],{"class":1152},[1050,5513,1221],{"class":1064},[1050,5515,5516],{"class":1214},"*",[1050,5518,5519],{"class":1152},"order_fields",[1050,5521,1233],{"class":1064},[1050,5523,5524],{"class":1052,"line":2748},[1050,5525,1122],{"emptyLinePlaceholder":1121},[1050,5527,5528],{"class":1052,"line":2776},[1050,5529,5223],{"class":1128},[1050,5531,5532,5534,5536,5538],{"class":1052,"line":2781},[1050,5533,1135],{"class":1060},[1050,5535,1138],{"class":1064},[1050,5537,5320],{"class":1152},[1050,5539,1156],{"class":1064},[1050,5541,5542,5545,5547,5549,5551,5553],{"class":1052,"line":2787},[1050,5543,5544],{"class":1162},"    primary_sort",[1050,5546,1138],{"class":1064},[1050,5548,1169],{"class":1168},[1050,5550,3955],{"class":1172},[1050,5552,1169],{"class":1168},[1050,5554,1178],{"class":1064},[1050,5556,5557,5560,5562,5564,5567,5569],{"class":1052,"line":2818},[1050,5558,5559],{"class":1162},"    secondary_sort",[1050,5561,1138],{"class":1064},[1050,5563,1169],{"class":1168},[1050,5565,5566],{"class":1172},"-view_count",[1050,5568,1169],{"class":1168},[1050,5570,1178],{"class":1064},[1050,5572,5573,5575,5577,5579,5581],{"class":1052,"line":2849},[1050,5574,1163],{"class":1162},[1050,5576,1138],{"class":1064},[1050,5578,1169],{"class":1168},[1050,5580,1173],{"class":1172},[1050,5582,3696],{"class":1168},[1050,5584,5585],{"class":1052,"line":2877},[1050,5586,1233],{"class":1064},[1030,5588,5590],{"id":5589},"slicing-and-pagination","Slicing and Pagination",[1035,5592,5594],{"id":5593},"basic-slicing","Basic Slicing",[1040,5596,5598],{"className":1042,"code":5597,"language":1044,"meta":1045,"style":1045},"# Get first 10 posts\nposts = Post.objects.all()[:10]\n\n# Get posts 10-20 (pagination)\nposts = Post.objects.all()[10:20]\n\n# Get first post\nfirst_post = Post.objects.all()[0]  # Raises IndexError if empty\nfirst_post = Post.objects.first()   # Returns None if empty\n\n# Get last post\nlast_post = Post.objects.all()[-1]  # Not supported, use:\nlast_post = Post.objects.last()\n\n# Skip first 5 posts\nposts = Post.objects.all()[5:]\n\n# Negative indexing (not supported directly)\n# Use reverse() and positive indexing instead\nlast_5_posts = Post.objects.order_by('-created_at')[:5]\n",[1047,5599,5600,5605,5629,5633,5638,5666,5670,5675,5703,5725,5729,5734,5763,5782,5786,5791,5815,5819,5824,5829],{"__ignoreMap":1045},[1050,5601,5602],{"class":1052,"line":1053},[1050,5603,5604],{"class":1128},"# Get first 10 posts\n",[1050,5606,5607,5609,5611,5613,5615,5617,5619,5622,5625,5627],{"class":1052,"line":1088},[1050,5608,1135],{"class":1060},[1050,5610,1138],{"class":1064},[1050,5612,1141],{"class":1060},[1050,5614,1065],{"class":1064},[1050,5616,1147],{"class":1146},[1050,5618,1065],{"class":1064},[1050,5620,5621],{"class":1152},"all",[1050,5623,5624],{"class":1064},"()[:",[1050,5626,3811],{"class":1229},[1050,5628,2952],{"class":1064},[1050,5630,5631],{"class":1052,"line":1105},[1050,5632,1122],{"emptyLinePlaceholder":1121},[1050,5634,5635],{"class":1052,"line":1118},[1050,5636,5637],{"class":1128},"# Get posts 10-20 (pagination)\n",[1050,5639,5640,5642,5644,5646,5648,5650,5652,5654,5657,5659,5661,5664],{"class":1052,"line":1125},[1050,5641,1135],{"class":1060},[1050,5643,1138],{"class":1064},[1050,5645,1141],{"class":1060},[1050,5647,1065],{"class":1064},[1050,5649,1147],{"class":1146},[1050,5651,1065],{"class":1064},[1050,5653,5621],{"class":1152},[1050,5655,5656],{"class":1064},"()[",[1050,5658,3811],{"class":1229},[1050,5660,4986],{"class":1064},[1050,5662,5663],{"class":1229},"20",[1050,5665,2952],{"class":1064},[1050,5667,5668],{"class":1052,"line":1132},[1050,5669,1122],{"emptyLinePlaceholder":1121},[1050,5671,5672],{"class":1052,"line":1159},[1050,5673,5674],{"class":1128},"# Get first post\n",[1050,5676,5677,5680,5682,5684,5686,5688,5690,5692,5694,5697,5700],{"class":1052,"line":1181},[1050,5678,5679],{"class":1060},"first_post ",[1050,5681,1138],{"class":1064},[1050,5683,1141],{"class":1060},[1050,5685,1065],{"class":1064},[1050,5687,1147],{"class":1146},[1050,5689,1065],{"class":1064},[1050,5691,5621],{"class":1152},[1050,5693,5656],{"class":1064},[1050,5695,5696],{"class":1229},"0",[1050,5698,5699],{"class":1064},"]",[1050,5701,5702],{"class":1128},"  # Raises IndexError if empty\n",[1050,5704,5705,5707,5709,5711,5713,5715,5717,5720,5722],{"class":1052,"line":1195},[1050,5706,5679],{"class":1060},[1050,5708,1138],{"class":1064},[1050,5710,1141],{"class":1060},[1050,5712,1065],{"class":1064},[1050,5714,1147],{"class":1146},[1050,5716,1065],{"class":1064},[1050,5718,5719],{"class":1152},"first",[1050,5721,1211],{"class":1064},[1050,5723,5724],{"class":1128},"   # Returns None if empty\n",[1050,5726,5727],{"class":1052,"line":1236},[1050,5728,1122],{"emptyLinePlaceholder":1121},[1050,5730,5731],{"class":1052,"line":1241},[1050,5732,5733],{"class":1128},"# Get last post\n",[1050,5735,5736,5739,5741,5743,5745,5747,5749,5751,5753,5756,5758,5760],{"class":1052,"line":1246},[1050,5737,5738],{"class":1060},"last_post ",[1050,5740,1138],{"class":1064},[1050,5742,1141],{"class":1060},[1050,5744,1065],{"class":1064},[1050,5746,1147],{"class":1146},[1050,5748,1065],{"class":1064},[1050,5750,5621],{"class":1152},[1050,5752,5656],{"class":1064},[1050,5754,5755],{"class":1214},"-",[1050,5757,2431],{"class":1229},[1050,5759,5699],{"class":1064},[1050,5761,5762],{"class":1128},"  # Not supported, use:\n",[1050,5764,5765,5767,5769,5771,5773,5775,5777,5780],{"class":1052,"line":1252},[1050,5766,5738],{"class":1060},[1050,5768,1138],{"class":1064},[1050,5770,1141],{"class":1060},[1050,5772,1065],{"class":1064},[1050,5774,1147],{"class":1146},[1050,5776,1065],{"class":1064},[1050,5778,5779],{"class":1152},"last",[1050,5781,2576],{"class":1064},[1050,5783,5784],{"class":1052,"line":1288},[1050,5785,1122],{"emptyLinePlaceholder":1121},[1050,5787,5788],{"class":1052,"line":1309},[1050,5789,5790],{"class":1128},"# Skip first 5 posts\n",[1050,5792,5793,5795,5797,5799,5801,5803,5805,5807,5809,5812],{"class":1052,"line":1346},[1050,5794,1135],{"class":1060},[1050,5796,1138],{"class":1064},[1050,5798,1141],{"class":1060},[1050,5800,1065],{"class":1064},[1050,5802,1147],{"class":1146},[1050,5804,1065],{"class":1064},[1050,5806,5621],{"class":1152},[1050,5808,5656],{"class":1064},[1050,5810,5811],{"class":1229},"5",[1050,5813,5814],{"class":1064},":]\n",[1050,5816,5817],{"class":1052,"line":1351},[1050,5818,1122],{"emptyLinePlaceholder":1121},[1050,5820,5821],{"class":1052,"line":1357},[1050,5822,5823],{"class":1128},"# Negative indexing (not supported directly)\n",[1050,5825,5826],{"class":1052,"line":1392},[1050,5827,5828],{"class":1128},"# Use reverse() and positive indexing instead\n",[1050,5830,5831,5834,5836,5838,5840,5842,5844,5846,5848,5850,5852,5854,5857,5859],{"class":1052,"line":1415},[1050,5832,5833],{"class":1060},"last_5_posts ",[1050,5835,1138],{"class":1064},[1050,5837,1141],{"class":1060},[1050,5839,1065],{"class":1064},[1050,5841,1147],{"class":1146},[1050,5843,1065],{"class":1064},[1050,5845,3879],{"class":1152},[1050,5847,1221],{"class":1064},[1050,5849,1169],{"class":1168},[1050,5851,3916],{"class":1172},[1050,5853,1169],{"class":1168},[1050,5855,5856],{"class":1064},")[:",[1050,5858,5811],{"class":1229},[1050,5860,2952],{"class":1064},[1035,5862,5864],{"id":5863},"pagination-patterns","Pagination Patterns",[1040,5866,5868],{"className":1042,"code":5867,"language":1044,"meta":1045,"style":1045},"from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger\n\ndef paginated_posts(request, posts_per_page=10):\n    \"\"\"Basic pagination example\"\"\"\n    \n    posts = Post.objects.filter(status='published').order_by('-created_at')\n    paginator = Paginator(posts, posts_per_page)\n    \n    page = request.GET.get('page', 1)\n    \n    try:\n        posts_page = paginator.page(page)\n    except PageNotAnInteger:\n        posts_page = paginator.page(1)\n    except EmptyPage:\n        posts_page = paginator.page(paginator.num_pages)\n    \n    return posts_page\n\n# Advanced pagination with search and filtering\ndef filtered_paginated_posts(request):\n    \"\"\"Pagination with search and filtering\"\"\"\n    \n    # Get filter parameters\n    search = request.GET.get('search', '')\n    category = request.GET.get('category', '')\n    author = request.GET.get('author', '')\n    \n    # Build query\n    posts = Post.objects.filter(status='published')\n    \n    if search:\n        posts = posts.filter(\n            Q(title__icontains=search) | Q(content__icontains=search)\n        )\n    \n    if category:\n        posts = posts.filter(category__slug=category)\n    \n    if author:\n        posts = posts.filter(author__slug=author)\n    \n    posts = posts.order_by('-created_at')\n    \n    # Paginate\n    paginator = Paginator(posts, 12)\n    page = request.GET.get('page', 1)\n    \n    try:\n        posts_page = paginator.page(page)\n    except (PageNotAnInteger, EmptyPage):\n        posts_page = paginator.page(1)\n    \n    return {\n        'posts': posts_page,\n        'search': search,\n        'category': category,\n        'author': author,\n        'total_count': paginator.count\n    }\n\n# Cursor-based pagination for large datasets\ndef cursor_paginated_posts(cursor=None, limit=20):\n    \"\"\"Cursor-based pagination for better performance on large datasets\"\"\"\n    \n    posts = Post.objects.filter(status='published').order_by('-id')\n    \n    if cursor:\n        posts = posts.filter(id__lt=cursor)\n    \n    posts_list = list(posts[:limit + 1])  # Get one extra to check if more exist\n    \n    has_next = len(posts_list) > limit\n    if has_next:\n        posts_list = posts_list[:-1]  # Remove the extra item\n    \n    next_cursor = posts_list[-1].id if posts_list and has_next else None\n    \n    return {\n        'posts': posts_list,\n        'next_cursor': next_cursor,\n        'has_next': has_next\n    }\n",[1047,5869,5870,5901,5905,5928,5937,5941,5984,6003,6007,6043,6047,6054,6074,6084,6102,6110,6134,6138,6145,6149,6154,6167,6176,6180,6185,6218,6249,6280,6284,6289,6319,6323,6332,6348,6377,6382,6386,6395,6417,6421,6430,6453,6457,6479,6483,6488,6507,6537,6541,6547,6565,6581,6599,6603,6609,6624,6638,6652,6666,6684,6688,6692,6697,6724,6733,6737,6780,6784,6793,6817,6822,6855,6860,6885,6895,6917,6922,6963,6968,6975,6990,7007,7022],{"__ignoreMap":1045},[1050,5871,5872,5874,5876,5878,5881,5883,5886,5888,5891,5893,5896,5898],{"class":1052,"line":1053},[1050,5873,1057],{"class":1056},[1050,5875,1061],{"class":1060},[1050,5877,1065],{"class":1064},[1050,5879,5880],{"class":1060},"core",[1050,5882,1065],{"class":1064},[1050,5884,5885],{"class":1060},"paginator ",[1050,5887,1076],{"class":1056},[1050,5889,5890],{"class":1060}," Paginator",[1050,5892,1082],{"class":1064},[1050,5894,5895],{"class":1060}," EmptyPage",[1050,5897,1082],{"class":1064},[1050,5899,5900],{"class":1060}," PageNotAnInteger\n",[1050,5902,5903],{"class":1052,"line":1088},[1050,5904,1122],{"emptyLinePlaceholder":1121},[1050,5906,5907,5909,5912,5914,5917,5919,5922,5924,5926],{"class":1052,"line":1105},[1050,5908,4912],{"class":3161},[1050,5910,5911],{"class":4915}," paginated_posts",[1050,5913,1221],{"class":1064},[1050,5915,5916],{"class":4921},"request",[1050,5918,1082],{"class":1064},[1050,5920,5921],{"class":4921}," posts_per_page",[1050,5923,1138],{"class":1214},[1050,5925,3811],{"class":1229},[1050,5927,4946],{"class":1064},[1050,5929,5930,5932,5935],{"class":1052,"line":1118},[1050,5931,4952],{"class":4951},[1050,5933,5934],{"class":4955},"Basic pagination example",[1050,5936,4959],{"class":4951},[1050,5938,5939],{"class":1052,"line":1125},[1050,5940,4964],{"class":1060},[1050,5942,5943,5946,5948,5950,5952,5954,5956,5958,5960,5962,5964,5966,5968,5970,5972,5974,5976,5978,5980,5982],{"class":1052,"line":1132},[1050,5944,5945],{"class":1060},"    posts ",[1050,5947,1138],{"class":1064},[1050,5949,1141],{"class":1060},[1050,5951,1065],{"class":1064},[1050,5953,1147],{"class":1146},[1050,5955,1065],{"class":1064},[1050,5957,1153],{"class":1152},[1050,5959,1221],{"class":1064},[1050,5961,1271],{"class":1162},[1050,5963,1138],{"class":1064},[1050,5965,1169],{"class":1168},[1050,5967,1173],{"class":1172},[1050,5969,1169],{"class":1168},[1050,5971,3564],{"class":1064},[1050,5973,3879],{"class":1152},[1050,5975,1221],{"class":1064},[1050,5977,1169],{"class":1168},[1050,5979,3916],{"class":1172},[1050,5981,1169],{"class":1168},[1050,5983,1233],{"class":1064},[1050,5985,5986,5989,5991,5993,5995,5997,5999,6001],{"class":1052,"line":1159},[1050,5987,5988],{"class":1060},"    paginator ",[1050,5990,1138],{"class":1064},[1050,5992,5890],{"class":1152},[1050,5994,1221],{"class":1064},[1050,5996,3791],{"class":1152},[1050,5998,1082],{"class":1064},[1050,6000,5921],{"class":1152},[1050,6002,1233],{"class":1064},[1050,6004,6005],{"class":1052,"line":1181},[1050,6006,4964],{"class":1060},[1050,6008,6009,6012,6014,6017,6019,6023,6025,6027,6029,6031,6034,6036,6038,6041],{"class":1052,"line":1195},[1050,6010,6011],{"class":1060},"    page ",[1050,6013,1138],{"class":1064},[1050,6015,6016],{"class":1060}," request",[1050,6018,1065],{"class":1064},[1050,6020,6022],{"class":6021},"sFGJz","GET",[1050,6024,1065],{"class":1064},[1050,6026,5110],{"class":1152},[1050,6028,1221],{"class":1064},[1050,6030,1169],{"class":1168},[1050,6032,6033],{"class":1172},"page",[1050,6035,1169],{"class":1168},[1050,6037,1082],{"class":1064},[1050,6039,6040],{"class":1229}," 1",[1050,6042,1233],{"class":1064},[1050,6044,6045],{"class":1052,"line":1236},[1050,6046,4964],{"class":1060},[1050,6048,6049,6052],{"class":1052,"line":1241},[1050,6050,6051],{"class":1056},"    try",[1050,6053,5148],{"class":1064},[1050,6055,6056,6059,6061,6064,6066,6068,6070,6072],{"class":1052,"line":1246},[1050,6057,6058],{"class":1060},"        posts_page ",[1050,6060,1138],{"class":1064},[1050,6062,6063],{"class":1060}," paginator",[1050,6065,1065],{"class":1064},[1050,6067,6033],{"class":1152},[1050,6069,1221],{"class":1064},[1050,6071,6033],{"class":1152},[1050,6073,1233],{"class":1064},[1050,6075,6076,6079,6082],{"class":1052,"line":1252},[1050,6077,6078],{"class":1056},"    except",[1050,6080,6081],{"class":1060}," PageNotAnInteger",[1050,6083,5148],{"class":1064},[1050,6085,6086,6088,6090,6092,6094,6096,6098,6100],{"class":1052,"line":1288},[1050,6087,6058],{"class":1060},[1050,6089,1138],{"class":1064},[1050,6091,6063],{"class":1060},[1050,6093,1065],{"class":1064},[1050,6095,6033],{"class":1152},[1050,6097,1221],{"class":1064},[1050,6099,2431],{"class":1229},[1050,6101,1233],{"class":1064},[1050,6103,6104,6106,6108],{"class":1052,"line":1309},[1050,6105,6078],{"class":1056},[1050,6107,5895],{"class":1060},[1050,6109,5148],{"class":1064},[1050,6111,6112,6114,6116,6118,6120,6122,6124,6127,6129,6132],{"class":1052,"line":1346},[1050,6113,6058],{"class":1060},[1050,6115,1138],{"class":1064},[1050,6117,6063],{"class":1060},[1050,6119,1065],{"class":1064},[1050,6121,6033],{"class":1152},[1050,6123,1221],{"class":1064},[1050,6125,6126],{"class":1152},"paginator",[1050,6128,1065],{"class":1064},[1050,6130,6131],{"class":1146},"num_pages",[1050,6133,1233],{"class":1064},[1050,6135,6136],{"class":1052,"line":1351},[1050,6137,4964],{"class":1060},[1050,6139,6140,6142],{"class":1052,"line":1357},[1050,6141,5182],{"class":1056},[1050,6143,6144],{"class":1060}," posts_page\n",[1050,6146,6147],{"class":1052,"line":1392},[1050,6148,1122],{"emptyLinePlaceholder":1121},[1050,6150,6151],{"class":1052,"line":1415},[1050,6152,6153],{"class":1128},"# Advanced pagination with search and filtering\n",[1050,6155,6156,6158,6161,6163,6165],{"class":1052,"line":1420},[1050,6157,4912],{"class":3161},[1050,6159,6160],{"class":4915}," filtered_paginated_posts",[1050,6162,1221],{"class":1064},[1050,6164,5916],{"class":4921},[1050,6166,4946],{"class":1064},[1050,6168,6169,6171,6174],{"class":1052,"line":1426},[1050,6170,4952],{"class":4951},[1050,6172,6173],{"class":4955},"Pagination with search and filtering",[1050,6175,4959],{"class":4951},[1050,6177,6178],{"class":1052,"line":1459},[1050,6179,4964],{"class":1060},[1050,6181,6182],{"class":1052,"line":1482},[1050,6183,6184],{"class":1128},"    # Get filter parameters\n",[1050,6186,6187,6190,6192,6194,6196,6198,6200,6202,6204,6206,6209,6211,6213,6216],{"class":1052,"line":1487},[1050,6188,6189],{"class":1060},"    search ",[1050,6191,1138],{"class":1064},[1050,6193,6016],{"class":1060},[1050,6195,1065],{"class":1064},[1050,6197,6022],{"class":6021},[1050,6199,1065],{"class":1064},[1050,6201,5110],{"class":1152},[1050,6203,1221],{"class":1064},[1050,6205,1169],{"class":1168},[1050,6207,6208],{"class":1172},"search",[1050,6210,1169],{"class":1168},[1050,6212,1082],{"class":1064},[1050,6214,6215],{"class":1168}," ''",[1050,6217,1233],{"class":1064},[1050,6219,6220,6223,6225,6227,6229,6231,6233,6235,6237,6239,6241,6243,6245,6247],{"class":1052,"line":1493},[1050,6221,6222],{"class":1060},"    category ",[1050,6224,1138],{"class":1064},[1050,6226,6016],{"class":1060},[1050,6228,1065],{"class":1064},[1050,6230,6022],{"class":6021},[1050,6232,1065],{"class":1064},[1050,6234,5110],{"class":1152},[1050,6236,1221],{"class":1064},[1050,6238,1169],{"class":1168},[1050,6240,5038],{"class":1172},[1050,6242,1169],{"class":1168},[1050,6244,1082],{"class":1064},[1050,6246,6215],{"class":1168},[1050,6248,1233],{"class":1064},[1050,6250,6251,6254,6256,6258,6260,6262,6264,6266,6268,6270,6272,6274,6276,6278],{"class":1052,"line":1539},[1050,6252,6253],{"class":1060},"    author ",[1050,6255,1138],{"class":1064},[1050,6257,6016],{"class":1060},[1050,6259,1065],{"class":1064},[1050,6261,6022],{"class":6021},[1050,6263,1065],{"class":1064},[1050,6265,5110],{"class":1152},[1050,6267,1221],{"class":1064},[1050,6269,1169],{"class":1168},[1050,6271,5019],{"class":1172},[1050,6273,1169],{"class":1168},[1050,6275,1082],{"class":1064},[1050,6277,6215],{"class":1168},[1050,6279,1233],{"class":1064},[1050,6281,6282],{"class":1052,"line":1584},[1050,6283,4964],{"class":1060},[1050,6285,6286],{"class":1052,"line":1623},[1050,6287,6288],{"class":1128},"    # Build query\n",[1050,6290,6291,6293,6295,6297,6299,6301,6303,6305,6307,6309,6311,6313,6315,6317],{"class":1052,"line":1628},[1050,6292,5945],{"class":1060},[1050,6294,1138],{"class":1064},[1050,6296,1141],{"class":1060},[1050,6298,1065],{"class":1064},[1050,6300,1147],{"class":1146},[1050,6302,1065],{"class":1064},[1050,6304,1153],{"class":1152},[1050,6306,1221],{"class":1064},[1050,6308,1271],{"class":1162},[1050,6310,1138],{"class":1064},[1050,6312,1169],{"class":1168},[1050,6314,1173],{"class":1172},[1050,6316,1169],{"class":1168},[1050,6318,1233],{"class":1064},[1050,6320,6321],{"class":1052,"line":1662},[1050,6322,4964],{"class":1060},[1050,6324,6325,6327,6330],{"class":1052,"line":1667},[1050,6326,5133],{"class":1056},[1050,6328,6329],{"class":1060}," search",[1050,6331,5148],{"class":1064},[1050,6333,6334,6337,6339,6342,6344,6346],{"class":1052,"line":1673},[1050,6335,6336],{"class":1060},"        posts ",[1050,6338,1138],{"class":1064},[1050,6340,6341],{"class":1060}," posts",[1050,6343,1065],{"class":1064},[1050,6345,1153],{"class":1152},[1050,6347,1156],{"class":1064},[1050,6349,6350,6353,6355,6357,6359,6361,6363,6365,6367,6369,6371,6373,6375],{"class":1052,"line":1692},[1050,6351,6352],{"class":1152},"            Q",[1050,6354,1221],{"class":1064},[1050,6356,1505],{"class":1162},[1050,6358,1138],{"class":1064},[1050,6360,6208],{"class":1152},[1050,6362,1282],{"class":1064},[1050,6364,1519],{"class":1214},[1050,6366,1079],{"class":1152},[1050,6368,1221],{"class":1064},[1050,6370,1526],{"class":1162},[1050,6372,1138],{"class":1064},[1050,6374,6208],{"class":1152},[1050,6376,1233],{"class":1064},[1050,6378,6379],{"class":1052,"line":1718},[1050,6380,6381],{"class":1064},"        )\n",[1050,6383,6384],{"class":1052,"line":1766},[1050,6385,4964],{"class":1060},[1050,6387,6388,6390,6393],{"class":1052,"line":1789},[1050,6389,5133],{"class":1056},[1050,6391,6392],{"class":1060}," category",[1050,6394,5148],{"class":1064},[1050,6396,6397,6399,6401,6403,6405,6407,6409,6411,6413,6415],{"class":1052,"line":2642},[1050,6398,6336],{"class":1060},[1050,6400,1138],{"class":1064},[1050,6402,6341],{"class":1060},[1050,6404,1065],{"class":1064},[1050,6406,1153],{"class":1152},[1050,6408,1221],{"class":1064},[1050,6410,1551],{"class":1162},[1050,6412,1138],{"class":1064},[1050,6414,5038],{"class":1152},[1050,6416,1233],{"class":1064},[1050,6418,6419],{"class":1052,"line":2654},[1050,6420,4964],{"class":1060},[1050,6422,6423,6425,6428],{"class":1052,"line":2677},[1050,6424,5133],{"class":1056},[1050,6426,6427],{"class":1060}," author",[1050,6429,5148],{"class":1064},[1050,6431,6432,6434,6436,6438,6440,6442,6444,6447,6449,6451],{"class":1052,"line":2706},[1050,6433,6336],{"class":1060},[1050,6435,1138],{"class":1064},[1050,6437,6341],{"class":1060},[1050,6439,1065],{"class":1064},[1050,6441,1153],{"class":1152},[1050,6443,1221],{"class":1064},[1050,6445,6446],{"class":1162},"author__slug",[1050,6448,1138],{"class":1064},[1050,6450,5019],{"class":1152},[1050,6452,1233],{"class":1064},[1050,6454,6455],{"class":1052,"line":2711},[1050,6456,4964],{"class":1060},[1050,6458,6459,6461,6463,6465,6467,6469,6471,6473,6475,6477],{"class":1052,"line":2717},[1050,6460,5945],{"class":1060},[1050,6462,1138],{"class":1064},[1050,6464,6341],{"class":1060},[1050,6466,1065],{"class":1064},[1050,6468,3879],{"class":1152},[1050,6470,1221],{"class":1064},[1050,6472,1169],{"class":1168},[1050,6474,3916],{"class":1172},[1050,6476,1169],{"class":1168},[1050,6478,1233],{"class":1064},[1050,6480,6481],{"class":1052,"line":2748},[1050,6482,4964],{"class":1060},[1050,6484,6485],{"class":1052,"line":2776},[1050,6486,6487],{"class":1128},"    # Paginate\n",[1050,6489,6490,6492,6494,6496,6498,6500,6502,6505],{"class":1052,"line":2781},[1050,6491,5988],{"class":1060},[1050,6493,1138],{"class":1064},[1050,6495,5890],{"class":1152},[1050,6497,1221],{"class":1064},[1050,6499,3791],{"class":1152},[1050,6501,1082],{"class":1064},[1050,6503,6504],{"class":1229}," 12",[1050,6506,1233],{"class":1064},[1050,6508,6509,6511,6513,6515,6517,6519,6521,6523,6525,6527,6529,6531,6533,6535],{"class":1052,"line":2787},[1050,6510,6011],{"class":1060},[1050,6512,1138],{"class":1064},[1050,6514,6016],{"class":1060},[1050,6516,1065],{"class":1064},[1050,6518,6022],{"class":6021},[1050,6520,1065],{"class":1064},[1050,6522,5110],{"class":1152},[1050,6524,1221],{"class":1064},[1050,6526,1169],{"class":1168},[1050,6528,6033],{"class":1172},[1050,6530,1169],{"class":1168},[1050,6532,1082],{"class":1064},[1050,6534,6040],{"class":1229},[1050,6536,1233],{"class":1064},[1050,6538,6539],{"class":1052,"line":2818},[1050,6540,4964],{"class":1060},[1050,6542,6543,6545],{"class":1052,"line":2849},[1050,6544,6051],{"class":1056},[1050,6546,5148],{"class":1064},[1050,6548,6549,6551,6553,6555,6557,6559,6561,6563],{"class":1052,"line":2877},[1050,6550,6058],{"class":1060},[1050,6552,1138],{"class":1064},[1050,6554,6063],{"class":1060},[1050,6556,1065],{"class":1064},[1050,6558,6033],{"class":1152},[1050,6560,1221],{"class":1064},[1050,6562,6033],{"class":1152},[1050,6564,1233],{"class":1064},[1050,6566,6567,6569,6572,6575,6577,6579],{"class":1052,"line":2908},[1050,6568,6078],{"class":1056},[1050,6570,6571],{"class":1064}," (",[1050,6573,6574],{"class":1060},"PageNotAnInteger",[1050,6576,1082],{"class":1064},[1050,6578,5895],{"class":1060},[1050,6580,4946],{"class":1064},[1050,6582,6583,6585,6587,6589,6591,6593,6595,6597],{"class":1052,"line":2913},[1050,6584,6058],{"class":1060},[1050,6586,1138],{"class":1064},[1050,6588,6063],{"class":1060},[1050,6590,1065],{"class":1064},[1050,6592,6033],{"class":1152},[1050,6594,1221],{"class":1064},[1050,6596,2431],{"class":1229},[1050,6598,1233],{"class":1064},[1050,6600,6601],{"class":1052,"line":2919},[1050,6602,4964],{"class":1060},[1050,6604,6605,6607],{"class":1052,"line":2955},[1050,6606,5182],{"class":1056},[1050,6608,4974],{"class":1064},[1050,6610,6611,6613,6615,6617,6619,6622],{"class":1052,"line":2984},[1050,6612,4979],{"class":1168},[1050,6614,3791],{"class":1172},[1050,6616,1169],{"class":1168},[1050,6618,4986],{"class":1064},[1050,6620,6621],{"class":1060}," posts_page",[1050,6623,1178],{"class":1064},[1050,6625,6626,6628,6630,6632,6634,6636],{"class":1052,"line":2989},[1050,6627,4979],{"class":1168},[1050,6629,6208],{"class":1172},[1050,6631,1169],{"class":1168},[1050,6633,4986],{"class":1064},[1050,6635,6329],{"class":1060},[1050,6637,1178],{"class":1064},[1050,6639,6640,6642,6644,6646,6648,6650],{"class":1052,"line":3026},[1050,6641,4979],{"class":1168},[1050,6643,5038],{"class":1172},[1050,6645,1169],{"class":1168},[1050,6647,4986],{"class":1064},[1050,6649,6392],{"class":1060},[1050,6651,1178],{"class":1064},[1050,6653,6654,6656,6658,6660,6662,6664],{"class":1052,"line":3055},[1050,6655,4979],{"class":1168},[1050,6657,5019],{"class":1172},[1050,6659,1169],{"class":1168},[1050,6661,4986],{"class":1064},[1050,6663,6427],{"class":1060},[1050,6665,1178],{"class":1064},[1050,6667,6668,6670,6673,6675,6677,6679,6681],{"class":1052,"line":3060},[1050,6669,4979],{"class":1168},[1050,6671,6672],{"class":1172},"total_count",[1050,6674,1169],{"class":1168},[1050,6676,4986],{"class":1064},[1050,6678,6063],{"class":1060},[1050,6680,1065],{"class":1064},[1050,6682,6683],{"class":1146},"count\n",[1050,6685,6686],{"class":1052,"line":3066},[1050,6687,5091],{"class":1064},[1050,6689,6690],{"class":1052,"line":3097},[1050,6691,1122],{"emptyLinePlaceholder":1121},[1050,6693,6694],{"class":1052,"line":3126},[1050,6695,6696],{"class":1128},"# Cursor-based pagination for large datasets\n",[1050,6698,6699,6701,6704,6706,6709,6711,6713,6715,6718,6720,6722],{"class":1052,"line":3131},[1050,6700,4912],{"class":3161},[1050,6702,6703],{"class":4915}," cursor_paginated_posts",[1050,6705,1221],{"class":1064},[1050,6707,6708],{"class":4921},"cursor",[1050,6710,1138],{"class":1214},[1050,6712,5330],{"class":1189},[1050,6714,1082],{"class":1064},[1050,6716,6717],{"class":4921}," limit",[1050,6719,1138],{"class":1214},[1050,6721,5663],{"class":1229},[1050,6723,4946],{"class":1064},[1050,6725,6726,6728,6731],{"class":1052,"line":3137},[1050,6727,4952],{"class":4951},[1050,6729,6730],{"class":4955},"Cursor-based pagination for better performance on large datasets",[1050,6732,4959],{"class":4951},[1050,6734,6735],{"class":1052,"line":3194},[1050,6736,4964],{"class":1060},[1050,6738,6739,6741,6743,6745,6747,6749,6751,6753,6755,6757,6759,6761,6763,6765,6767,6769,6771,6773,6776,6778],{"class":1052,"line":3247},[1050,6740,5945],{"class":1060},[1050,6742,1138],{"class":1064},[1050,6744,1141],{"class":1060},[1050,6746,1065],{"class":1064},[1050,6748,1147],{"class":1146},[1050,6750,1065],{"class":1064},[1050,6752,1153],{"class":1152},[1050,6754,1221],{"class":1064},[1050,6756,1271],{"class":1162},[1050,6758,1138],{"class":1064},[1050,6760,1169],{"class":1168},[1050,6762,1173],{"class":1172},[1050,6764,1169],{"class":1168},[1050,6766,3564],{"class":1064},[1050,6768,3879],{"class":1152},[1050,6770,1221],{"class":1064},[1050,6772,1169],{"class":1168},[1050,6774,6775],{"class":1172},"-id",[1050,6777,1169],{"class":1168},[1050,6779,1233],{"class":1064},[1050,6781,6782],{"class":1052,"line":3252},[1050,6783,4964],{"class":1060},[1050,6785,6786,6788,6791],{"class":1052,"line":3258},[1050,6787,5133],{"class":1056},[1050,6789,6790],{"class":1060}," cursor",[1050,6792,5148],{"class":1064},[1050,6794,6796,6798,6800,6802,6804,6806,6808,6811,6813,6815],{"class":1052,"line":6795},69,[1050,6797,6336],{"class":1060},[1050,6799,1138],{"class":1064},[1050,6801,6341],{"class":1060},[1050,6803,1065],{"class":1064},[1050,6805,1153],{"class":1152},[1050,6807,1221],{"class":1064},[1050,6809,6810],{"class":1162},"id__lt",[1050,6812,1138],{"class":1064},[1050,6814,6708],{"class":1152},[1050,6816,1233],{"class":1064},[1050,6818,6820],{"class":1052,"line":6819},70,[1050,6821,4964],{"class":1060},[1050,6823,6825,6828,6830,6834,6836,6838,6841,6844,6847,6849,6852],{"class":1052,"line":6824},71,[1050,6826,6827],{"class":1060},"    posts_list ",[1050,6829,1138],{"class":1064},[1050,6831,6833],{"class":6832},"sa2tF"," list",[1050,6835,1221],{"class":1064},[1050,6837,3791],{"class":1152},[1050,6839,6840],{"class":1064},"[:",[1050,6842,6843],{"class":1152},"limit ",[1050,6845,6846],{"class":1214},"+",[1050,6848,6040],{"class":1229},[1050,6850,6851],{"class":1064},"])",[1050,6853,6854],{"class":1128},"  # Get one extra to check if more exist\n",[1050,6856,6858],{"class":1052,"line":6857},72,[1050,6859,4964],{"class":1060},[1050,6861,6863,6866,6868,6872,6874,6877,6879,6882],{"class":1052,"line":6862},73,[1050,6864,6865],{"class":1060},"    has_next ",[1050,6867,1138],{"class":1064},[1050,6869,6871],{"class":6870},"sJdAF"," len",[1050,6873,1221],{"class":1064},[1050,6875,6876],{"class":1152},"posts_list",[1050,6878,1282],{"class":1064},[1050,6880,6881],{"class":1214}," >",[1050,6883,6884],{"class":1060}," limit\n",[1050,6886,6888,6890,6893],{"class":1052,"line":6887},74,[1050,6889,5133],{"class":1056},[1050,6891,6892],{"class":1060}," has_next",[1050,6894,5148],{"class":1064},[1050,6896,6898,6901,6903,6906,6908,6910,6912,6914],{"class":1052,"line":6897},75,[1050,6899,6900],{"class":1060},"        posts_list ",[1050,6902,1138],{"class":1064},[1050,6904,6905],{"class":1060}," posts_list",[1050,6907,6840],{"class":1064},[1050,6909,5755],{"class":1214},[1050,6911,2431],{"class":1229},[1050,6913,5699],{"class":1064},[1050,6915,6916],{"class":1128},"  # Remove the extra item\n",[1050,6918,6920],{"class":1052,"line":6919},76,[1050,6921,4964],{"class":1060},[1050,6923,6925,6928,6930,6932,6935,6937,6939,6942,6945,6948,6951,6954,6957,6960],{"class":1052,"line":6924},77,[1050,6926,6927],{"class":1060},"    next_cursor ",[1050,6929,1138],{"class":1064},[1050,6931,6905],{"class":1060},[1050,6933,6934],{"class":1064},"[",[1050,6936,5755],{"class":1214},[1050,6938,2431],{"class":1229},[1050,6940,6941],{"class":1064},"].",[1050,6943,6944],{"class":1146},"id",[1050,6946,6947],{"class":1056}," if",[1050,6949,6950],{"class":1060}," posts_list ",[1050,6952,6953],{"class":1214},"and",[1050,6955,6956],{"class":1060}," has_next ",[1050,6958,6959],{"class":1056},"else",[1050,6961,6962],{"class":1189}," None\n",[1050,6964,6966],{"class":1052,"line":6965},78,[1050,6967,4964],{"class":1060},[1050,6969,6971,6973],{"class":1052,"line":6970},79,[1050,6972,5182],{"class":1056},[1050,6974,4974],{"class":1064},[1050,6976,6978,6980,6982,6984,6986,6988],{"class":1052,"line":6977},80,[1050,6979,4979],{"class":1168},[1050,6981,3791],{"class":1172},[1050,6983,1169],{"class":1168},[1050,6985,4986],{"class":1064},[1050,6987,6905],{"class":1060},[1050,6989,1178],{"class":1064},[1050,6991,6993,6995,6998,7000,7002,7005],{"class":1052,"line":6992},81,[1050,6994,4979],{"class":1168},[1050,6996,6997],{"class":1172},"next_cursor",[1050,6999,1169],{"class":1168},[1050,7001,4986],{"class":1064},[1050,7003,7004],{"class":1060}," next_cursor",[1050,7006,1178],{"class":1064},[1050,7008,7010,7012,7015,7017,7019],{"class":1052,"line":7009},82,[1050,7011,4979],{"class":1168},[1050,7013,7014],{"class":1172},"has_next",[1050,7016,1169],{"class":1168},[1050,7018,4986],{"class":1064},[1050,7020,7021],{"class":1060}," has_next\n",[1050,7023,7025],{"class":1052,"line":7024},83,[1050,7026,5091],{"class":1064},[1035,7028,7030],{"id":7029},"efficient-slicing-techniques","Efficient Slicing Techniques",[1040,7032,7034],{"className":1042,"code":7033,"language":1044,"meta":1045,"style":1045},"# Efficient counting for pagination\ndef efficient_paginated_posts(page=1, per_page=10):\n    \"\"\"Efficient pagination that avoids counting when possible\"\"\"\n    \n    offset = (page - 1) * per_page\n    limit = per_page + 1  # Get one extra to check if more exist\n    \n    posts = Post.objects.filter(status='published') \\\n                       .order_by('-created_at')[offset:offset + limit]\n    \n    posts_list = list(posts)\n    has_next = len(posts_list) > per_page\n    \n    if has_next:\n        posts_list = posts_list[:-1]  # Remove the extra item\n    \n    return {\n        'posts': posts_list,\n        'has_next': has_next,\n        'has_previous': page > 1,\n        'current_page': page\n    }\n\n# Batch processing with slicing\ndef process_posts_in_batches(batch_size=1000):\n    \"\"\"Process large datasets in batches to avoid memory issues\"\"\"\n    \n    total_processed = 0\n    \n    while True:\n        posts = Post.objects.filter(\n            status='published',\n            processed=False\n        ).order_by('id')[:batch_size]\n        \n        posts_list = list(posts)\n        \n        if not posts_list:\n            break\n        \n        # Process batch\n        for post in posts_list:\n            # Do some processing\n            post.processed = True\n            post.save(update_fields=['processed'])\n        \n        total_processed += len(posts_list)\n        print(f\"Processed {total_processed} posts...\")\n        \n        # If we got fewer than batch_size, we're done\n        if len(posts_list) \u003C batch_size:\n            break\n    \n    return total_processed\n\n# Optimized slicing with select_related\ndef get_post_previews(limit=10):\n    \"\"\"Get post previews with optimized queries\"\"\"\n    \n    return Post.objects.select_related('author', 'category') \\\n                      .prefetch_related('tags') \\\n                      .filter(status='published') \\\n                      .only('title', 'slug', 'excerpt', 'created_at',\n                            'author__name', 'category__name') \\\n                      .order_by('-created_at')[:limit]\n",[1047,7035,7036,7041,7067,7076,7080,7103,7119,7123,7155,7187,7191,7205,7223,7227,7235,7253,7257,7263,7277,7291,7312,7326,7330,7334,7339,7357,7366,7370,7380,7384,7394,7412,7427,7437,7458,7463,7477,7481,7492,7497,7501,7506,7521,7526,7542,7566,7570,7586,7611,7615,7620,7640,7644,7648,7655,7659,7664,7682,7691,7695,7730,7751,7773,7816,7837],{"__ignoreMap":1045},[1050,7037,7038],{"class":1052,"line":1053},[1050,7039,7040],{"class":1128},"# Efficient counting for pagination\n",[1050,7042,7043,7045,7048,7050,7052,7054,7056,7058,7061,7063,7065],{"class":1052,"line":1088},[1050,7044,4912],{"class":3161},[1050,7046,7047],{"class":4915}," efficient_paginated_posts",[1050,7049,1221],{"class":1064},[1050,7051,6033],{"class":4921},[1050,7053,1138],{"class":1214},[1050,7055,2431],{"class":1229},[1050,7057,1082],{"class":1064},[1050,7059,7060],{"class":4921}," per_page",[1050,7062,1138],{"class":1214},[1050,7064,3811],{"class":1229},[1050,7066,4946],{"class":1064},[1050,7068,7069,7071,7074],{"class":1052,"line":1105},[1050,7070,4952],{"class":4951},[1050,7072,7073],{"class":4955},"Efficient pagination that avoids counting when possible",[1050,7075,4959],{"class":4951},[1050,7077,7078],{"class":1052,"line":1118},[1050,7079,4964],{"class":1060},[1050,7081,7082,7085,7087,7089,7092,7094,7096,7098,7100],{"class":1052,"line":1125},[1050,7083,7084],{"class":1060},"    offset ",[1050,7086,1138],{"class":1064},[1050,7088,6571],{"class":1064},[1050,7090,7091],{"class":1060},"page ",[1050,7093,5755],{"class":1214},[1050,7095,6040],{"class":1229},[1050,7097,1282],{"class":1064},[1050,7099,4278],{"class":1214},[1050,7101,7102],{"class":1060}," per_page\n",[1050,7104,7105,7108,7110,7113,7115,7117],{"class":1052,"line":1132},[1050,7106,7107],{"class":1060},"    limit ",[1050,7109,1138],{"class":1064},[1050,7111,7112],{"class":1060}," per_page ",[1050,7114,6846],{"class":1214},[1050,7116,6040],{"class":1229},[1050,7118,6854],{"class":1128},[1050,7120,7121],{"class":1052,"line":1159},[1050,7122,4964],{"class":1060},[1050,7124,7125,7127,7129,7131,7133,7135,7137,7139,7141,7143,7145,7147,7149,7151,7153],{"class":1052,"line":1181},[1050,7126,5945],{"class":1060},[1050,7128,1138],{"class":1064},[1050,7130,1141],{"class":1060},[1050,7132,1065],{"class":1064},[1050,7134,1147],{"class":1146},[1050,7136,1065],{"class":1064},[1050,7138,1153],{"class":1152},[1050,7140,1221],{"class":1064},[1050,7142,1271],{"class":1162},[1050,7144,1138],{"class":1064},[1050,7146,1169],{"class":1168},[1050,7148,1173],{"class":1172},[1050,7150,1169],{"class":1168},[1050,7152,1282],{"class":1064},[1050,7154,1285],{"class":1064},[1050,7156,7157,7160,7162,7164,7166,7168,7170,7173,7176,7178,7181,7183,7185],{"class":1052,"line":1195},[1050,7158,7159],{"class":1064},"                       .",[1050,7161,3879],{"class":1152},[1050,7163,1221],{"class":1064},[1050,7165,1169],{"class":1168},[1050,7167,3916],{"class":1172},[1050,7169,1169],{"class":1168},[1050,7171,7172],{"class":1064},")[",[1050,7174,7175],{"class":1060},"offset",[1050,7177,4986],{"class":1064},[1050,7179,7180],{"class":1060},"offset ",[1050,7182,6846],{"class":1214},[1050,7184,6717],{"class":1060},[1050,7186,2952],{"class":1064},[1050,7188,7189],{"class":1052,"line":1236},[1050,7190,4964],{"class":1060},[1050,7192,7193,7195,7197,7199,7201,7203],{"class":1052,"line":1241},[1050,7194,6827],{"class":1060},[1050,7196,1138],{"class":1064},[1050,7198,6833],{"class":6832},[1050,7200,1221],{"class":1064},[1050,7202,3791],{"class":1152},[1050,7204,1233],{"class":1064},[1050,7206,7207,7209,7211,7213,7215,7217,7219,7221],{"class":1052,"line":1246},[1050,7208,6865],{"class":1060},[1050,7210,1138],{"class":1064},[1050,7212,6871],{"class":6870},[1050,7214,1221],{"class":1064},[1050,7216,6876],{"class":1152},[1050,7218,1282],{"class":1064},[1050,7220,6881],{"class":1214},[1050,7222,7102],{"class":1060},[1050,7224,7225],{"class":1052,"line":1252},[1050,7226,4964],{"class":1060},[1050,7228,7229,7231,7233],{"class":1052,"line":1288},[1050,7230,5133],{"class":1056},[1050,7232,6892],{"class":1060},[1050,7234,5148],{"class":1064},[1050,7236,7237,7239,7241,7243,7245,7247,7249,7251],{"class":1052,"line":1309},[1050,7238,6900],{"class":1060},[1050,7240,1138],{"class":1064},[1050,7242,6905],{"class":1060},[1050,7244,6840],{"class":1064},[1050,7246,5755],{"class":1214},[1050,7248,2431],{"class":1229},[1050,7250,5699],{"class":1064},[1050,7252,6916],{"class":1128},[1050,7254,7255],{"class":1052,"line":1346},[1050,7256,4964],{"class":1060},[1050,7258,7259,7261],{"class":1052,"line":1351},[1050,7260,5182],{"class":1056},[1050,7262,4974],{"class":1064},[1050,7264,7265,7267,7269,7271,7273,7275],{"class":1052,"line":1357},[1050,7266,4979],{"class":1168},[1050,7268,3791],{"class":1172},[1050,7270,1169],{"class":1168},[1050,7272,4986],{"class":1064},[1050,7274,6905],{"class":1060},[1050,7276,1178],{"class":1064},[1050,7278,7279,7281,7283,7285,7287,7289],{"class":1052,"line":1392},[1050,7280,4979],{"class":1168},[1050,7282,7014],{"class":1172},[1050,7284,1169],{"class":1168},[1050,7286,4986],{"class":1064},[1050,7288,6892],{"class":1060},[1050,7290,1178],{"class":1064},[1050,7292,7293,7295,7298,7300,7302,7305,7308,7310],{"class":1052,"line":1415},[1050,7294,4979],{"class":1168},[1050,7296,7297],{"class":1172},"has_previous",[1050,7299,1169],{"class":1168},[1050,7301,4986],{"class":1064},[1050,7303,7304],{"class":1060}," page ",[1050,7306,7307],{"class":1214},">",[1050,7309,6040],{"class":1229},[1050,7311,1178],{"class":1064},[1050,7313,7314,7316,7319,7321,7323],{"class":1052,"line":1420},[1050,7315,4979],{"class":1168},[1050,7317,7318],{"class":1172},"current_page",[1050,7320,1169],{"class":1168},[1050,7322,4986],{"class":1064},[1050,7324,7325],{"class":1060}," page\n",[1050,7327,7328],{"class":1052,"line":1426},[1050,7329,5091],{"class":1064},[1050,7331,7332],{"class":1052,"line":1459},[1050,7333,1122],{"emptyLinePlaceholder":1121},[1050,7335,7336],{"class":1052,"line":1482},[1050,7337,7338],{"class":1128},"# Batch processing with slicing\n",[1050,7340,7341,7343,7346,7348,7351,7353,7355],{"class":1052,"line":1487},[1050,7342,4912],{"class":3161},[1050,7344,7345],{"class":4915}," process_posts_in_batches",[1050,7347,1221],{"class":1064},[1050,7349,7350],{"class":4921},"batch_size",[1050,7352,1138],{"class":1214},[1050,7354,2105],{"class":1229},[1050,7356,4946],{"class":1064},[1050,7358,7359,7361,7364],{"class":1052,"line":1493},[1050,7360,4952],{"class":4951},[1050,7362,7363],{"class":4955},"Process large datasets in batches to avoid memory issues",[1050,7365,4959],{"class":4951},[1050,7367,7368],{"class":1052,"line":1539},[1050,7369,4964],{"class":1060},[1050,7371,7372,7375,7377],{"class":1052,"line":1584},[1050,7373,7374],{"class":1060},"    total_processed ",[1050,7376,1138],{"class":1064},[1050,7378,7379],{"class":1229}," 0\n",[1050,7381,7382],{"class":1052,"line":1623},[1050,7383,4964],{"class":1060},[1050,7385,7386,7389,7392],{"class":1052,"line":1628},[1050,7387,7388],{"class":1056},"    while",[1050,7390,7391],{"class":1189}," True",[1050,7393,5148],{"class":1064},[1050,7395,7396,7398,7400,7402,7404,7406,7408,7410],{"class":1052,"line":1662},[1050,7397,6336],{"class":1060},[1050,7399,1138],{"class":1064},[1050,7401,1141],{"class":1060},[1050,7403,1065],{"class":1064},[1050,7405,1147],{"class":1146},[1050,7407,1065],{"class":1064},[1050,7409,1153],{"class":1152},[1050,7411,1156],{"class":1064},[1050,7413,7414,7417,7419,7421,7423,7425],{"class":1052,"line":1667},[1050,7415,7416],{"class":1162},"            status",[1050,7418,1138],{"class":1064},[1050,7420,1169],{"class":1168},[1050,7422,1173],{"class":1172},[1050,7424,1169],{"class":1168},[1050,7426,1178],{"class":1064},[1050,7428,7429,7432,7434],{"class":1052,"line":1673},[1050,7430,7431],{"class":1162},"            processed",[1050,7433,1138],{"class":1064},[1050,7435,7436],{"class":1189},"False\n",[1050,7438,7439,7442,7444,7446,7448,7450,7452,7454,7456],{"class":1052,"line":1692},[1050,7440,7441],{"class":1064},"        ).",[1050,7443,3879],{"class":1152},[1050,7445,1221],{"class":1064},[1050,7447,1169],{"class":1168},[1050,7449,6944],{"class":1172},[1050,7451,1169],{"class":1168},[1050,7453,5856],{"class":1064},[1050,7455,7350],{"class":1060},[1050,7457,2952],{"class":1064},[1050,7459,7460],{"class":1052,"line":1718},[1050,7461,7462],{"class":1060},"        \n",[1050,7464,7465,7467,7469,7471,7473,7475],{"class":1052,"line":1766},[1050,7466,6900],{"class":1060},[1050,7468,1138],{"class":1064},[1050,7470,6833],{"class":6832},[1050,7472,1221],{"class":1064},[1050,7474,3791],{"class":1152},[1050,7476,1233],{"class":1064},[1050,7478,7479],{"class":1052,"line":1789},[1050,7480,7462],{"class":1060},[1050,7482,7483,7486,7488,7490],{"class":1052,"line":2642},[1050,7484,7485],{"class":1056},"        if",[1050,7487,5474],{"class":1214},[1050,7489,6905],{"class":1060},[1050,7491,5148],{"class":1064},[1050,7493,7494],{"class":1052,"line":2654},[1050,7495,7496],{"class":1056},"            break\n",[1050,7498,7499],{"class":1052,"line":2677},[1050,7500,7462],{"class":1060},[1050,7502,7503],{"class":1052,"line":2706},[1050,7504,7505],{"class":1128},"        # Process batch\n",[1050,7507,7508,7511,7514,7517,7519],{"class":1052,"line":2711},[1050,7509,7510],{"class":1056},"        for",[1050,7512,7513],{"class":1060}," post ",[1050,7515,7516],{"class":1056},"in",[1050,7518,6905],{"class":1060},[1050,7520,5148],{"class":1064},[1050,7522,7523],{"class":1052,"line":2717},[1050,7524,7525],{"class":1128},"            # Do some processing\n",[1050,7527,7528,7531,7533,7536,7539],{"class":1052,"line":2748},[1050,7529,7530],{"class":1060},"            post",[1050,7532,1065],{"class":1064},[1050,7534,7535],{"class":1146},"processed",[1050,7537,7538],{"class":1064}," =",[1050,7540,7541],{"class":1189}," True\n",[1050,7543,7544,7546,7548,7551,7553,7556,7558,7560,7562,7564],{"class":1052,"line":2776},[1050,7545,7530],{"class":1060},[1050,7547,1065],{"class":1064},[1050,7549,7550],{"class":1152},"save",[1050,7552,1221],{"class":1064},[1050,7554,7555],{"class":1162},"update_fields",[1050,7557,3501],{"class":1064},[1050,7559,1169],{"class":1168},[1050,7561,7535],{"class":1172},[1050,7563,1169],{"class":1168},[1050,7565,3519],{"class":1064},[1050,7567,7568],{"class":1052,"line":2781},[1050,7569,7462],{"class":1060},[1050,7571,7572,7575,7578,7580,7582,7584],{"class":1052,"line":2787},[1050,7573,7574],{"class":1060},"        total_processed ",[1050,7576,7577],{"class":1064},"+=",[1050,7579,6871],{"class":6870},[1050,7581,1221],{"class":1064},[1050,7583,6876],{"class":1152},[1050,7585,1233],{"class":1064},[1050,7587,7588,7591,7593,7596,7599,7601,7604,7606,7609],{"class":1052,"line":2818},[1050,7589,7590],{"class":6870},"        print",[1050,7592,1221],{"class":1064},[1050,7594,7595],{"class":3161},"f",[1050,7597,7598],{"class":1172},"\"Processed ",[1050,7600,5165],{"class":5164},[1050,7602,7603],{"class":1152},"total_processed",[1050,7605,5171],{"class":5164},[1050,7607,7608],{"class":1172}," posts...\"",[1050,7610,1233],{"class":1064},[1050,7612,7613],{"class":1052,"line":2849},[1050,7614,7462],{"class":1060},[1050,7616,7617],{"class":1052,"line":2877},[1050,7618,7619],{"class":1128},"        # If we got fewer than batch_size, we're done\n",[1050,7621,7622,7624,7626,7628,7630,7632,7635,7638],{"class":1052,"line":2908},[1050,7623,7485],{"class":1056},[1050,7625,6871],{"class":6870},[1050,7627,1221],{"class":1064},[1050,7629,6876],{"class":1152},[1050,7631,1282],{"class":1064},[1050,7633,7634],{"class":1214}," \u003C",[1050,7636,7637],{"class":1060}," batch_size",[1050,7639,5148],{"class":1064},[1050,7641,7642],{"class":1052,"line":2913},[1050,7643,7496],{"class":1056},[1050,7645,7646],{"class":1052,"line":2919},[1050,7647,4964],{"class":1060},[1050,7649,7650,7652],{"class":1052,"line":2955},[1050,7651,5182],{"class":1056},[1050,7653,7654],{"class":1060}," total_processed\n",[1050,7656,7657],{"class":1052,"line":2984},[1050,7658,1122],{"emptyLinePlaceholder":1121},[1050,7660,7661],{"class":1052,"line":2989},[1050,7662,7663],{"class":1128},"# Optimized slicing with select_related\n",[1050,7665,7666,7668,7671,7673,7676,7678,7680],{"class":1052,"line":3026},[1050,7667,4912],{"class":3161},[1050,7669,7670],{"class":4915}," get_post_previews",[1050,7672,1221],{"class":1064},[1050,7674,7675],{"class":4921},"limit",[1050,7677,1138],{"class":1214},[1050,7679,3811],{"class":1229},[1050,7681,4946],{"class":1064},[1050,7683,7684,7686,7689],{"class":1052,"line":3055},[1050,7685,4952],{"class":4951},[1050,7687,7688],{"class":4955},"Get post previews with optimized queries",[1050,7690,4959],{"class":4951},[1050,7692,7693],{"class":1052,"line":3060},[1050,7694,4964],{"class":1060},[1050,7696,7697,7699,7701,7703,7705,7707,7710,7712,7714,7716,7718,7720,7722,7724,7726,7728],{"class":1052,"line":3066},[1050,7698,5182],{"class":1056},[1050,7700,1141],{"class":1060},[1050,7702,1065],{"class":1064},[1050,7704,1147],{"class":1146},[1050,7706,1065],{"class":1064},[1050,7708,7709],{"class":1152},"select_related",[1050,7711,1221],{"class":1064},[1050,7713,1169],{"class":1168},[1050,7715,5019],{"class":1172},[1050,7717,1169],{"class":1168},[1050,7719,1082],{"class":1064},[1050,7721,3008],{"class":1168},[1050,7723,5038],{"class":1172},[1050,7725,1169],{"class":1168},[1050,7727,1282],{"class":1064},[1050,7729,1285],{"class":1064},[1050,7731,7732,7735,7738,7740,7742,7745,7747,7749],{"class":1052,"line":3097},[1050,7733,7734],{"class":1064},"                      .",[1050,7736,7737],{"class":1152},"prefetch_related",[1050,7739,1221],{"class":1064},[1050,7741,1169],{"class":1168},[1050,7743,7744],{"class":1172},"tags",[1050,7746,1169],{"class":1168},[1050,7748,1282],{"class":1064},[1050,7750,1285],{"class":1064},[1050,7752,7753,7755,7757,7759,7761,7763,7765,7767,7769,7771],{"class":1052,"line":3126},[1050,7754,7734],{"class":1064},[1050,7756,1153],{"class":1152},[1050,7758,1221],{"class":1064},[1050,7760,1271],{"class":1162},[1050,7762,1138],{"class":1064},[1050,7764,1169],{"class":1168},[1050,7766,1173],{"class":1172},[1050,7768,1169],{"class":1168},[1050,7770,1282],{"class":1064},[1050,7772,1285],{"class":1064},[1050,7774,7775,7777,7780,7782,7784,7786,7788,7790,7792,7795,7797,7799,7801,7804,7806,7808,7810,7812,7814],{"class":1052,"line":3131},[1050,7776,7734],{"class":1064},[1050,7778,7779],{"class":1152},"only",[1050,7781,1221],{"class":1064},[1050,7783,1169],{"class":1168},[1050,7785,3972],{"class":1172},[1050,7787,1169],{"class":1168},[1050,7789,1082],{"class":1064},[1050,7791,3008],{"class":1168},[1050,7793,7794],{"class":1172},"slug",[1050,7796,1169],{"class":1168},[1050,7798,1082],{"class":1064},[1050,7800,3008],{"class":1168},[1050,7802,7803],{"class":1172},"excerpt",[1050,7805,1169],{"class":1168},[1050,7807,1082],{"class":1064},[1050,7809,3008],{"class":1168},[1050,7811,3886],{"class":1172},[1050,7813,1169],{"class":1168},[1050,7815,1178],{"class":1064},[1050,7817,7818,7821,7823,7825,7827,7829,7831,7833,7835],{"class":1052,"line":3137},[1050,7819,7820],{"class":1168},"                            '",[1050,7822,3296],{"class":1172},[1050,7824,1169],{"class":1168},[1050,7826,1082],{"class":1064},[1050,7828,3008],{"class":1168},[1050,7830,4042],{"class":1172},[1050,7832,1169],{"class":1168},[1050,7834,1282],{"class":1064},[1050,7836,1285],{"class":1064},[1050,7838,7839,7841,7843,7845,7847,7849,7851,7853,7855],{"class":1052,"line":3194},[1050,7840,7734],{"class":1064},[1050,7842,3879],{"class":1152},[1050,7844,1221],{"class":1064},[1050,7846,1169],{"class":1168},[1050,7848,3916],{"class":1172},[1050,7850,1169],{"class":1168},[1050,7852,5856],{"class":1064},[1050,7854,7675],{"class":1060},[1050,7856,2952],{"class":1064},[1035,7858,7860],{"id":7859},"performance-considerations","Performance Considerations",[1040,7862,7864],{"className":1042,"code":7863,"language":1044,"meta":1045,"style":1045},"# Avoid these patterns for large datasets:\n\n# DON'T: Count all records for simple pagination\n# total_count = Post.objects.count()  # Expensive on large tables\n\n# DON'T: Use offset for deep pagination\n# posts = Post.objects.all()[10000:10010]  # Slow for large offsets\n\n# DO: Use cursor-based pagination for large datasets\n# DO: Limit the fields you select\n# DO: Use database indexes on ordering fields\n# DO: Consider using database-level pagination\n\n# Example of optimized query for large datasets\ndef get_recent_posts_optimized(limit=20):\n    \"\"\"Optimized query for recent posts\"\"\"\n    \n    return Post.objects.select_related('author') \\\n                      .only('title', 'slug', 'created_at', 'author__name') \\\n                      .filter(status='published') \\\n                      .order_by('-created_at')[:limit]\n\n# Index recommendations for the above query:\n# CREATE INDEX idx_post_status_created ON blog_post(status, created_at DESC);\n# CREATE INDEX idx_author_name ON auth_user(first_name, last_name);\n",[1047,7865,7866,7871,7875,7880,7885,7889,7894,7899,7903,7908,7913,7918,7923,7927,7932,7949,7958,7962,7988,8030,8052,8072,8076,8081,8086],{"__ignoreMap":1045},[1050,7867,7868],{"class":1052,"line":1053},[1050,7869,7870],{"class":1128},"# Avoid these patterns for large datasets:\n",[1050,7872,7873],{"class":1052,"line":1088},[1050,7874,1122],{"emptyLinePlaceholder":1121},[1050,7876,7877],{"class":1052,"line":1105},[1050,7878,7879],{"class":1128},"# DON'T: Count all records for simple pagination\n",[1050,7881,7882],{"class":1052,"line":1118},[1050,7883,7884],{"class":1128},"# total_count = Post.objects.count()  # Expensive on large tables\n",[1050,7886,7887],{"class":1052,"line":1125},[1050,7888,1122],{"emptyLinePlaceholder":1121},[1050,7890,7891],{"class":1052,"line":1132},[1050,7892,7893],{"class":1128},"# DON'T: Use offset for deep pagination\n",[1050,7895,7896],{"class":1052,"line":1159},[1050,7897,7898],{"class":1128},"# posts = Post.objects.all()[10000:10010]  # Slow for large offsets\n",[1050,7900,7901],{"class":1052,"line":1181},[1050,7902,1122],{"emptyLinePlaceholder":1121},[1050,7904,7905],{"class":1052,"line":1195},[1050,7906,7907],{"class":1128},"# DO: Use cursor-based pagination for large datasets\n",[1050,7909,7910],{"class":1052,"line":1236},[1050,7911,7912],{"class":1128},"# DO: Limit the fields you select\n",[1050,7914,7915],{"class":1052,"line":1241},[1050,7916,7917],{"class":1128},"# DO: Use database indexes on ordering fields\n",[1050,7919,7920],{"class":1052,"line":1246},[1050,7921,7922],{"class":1128},"# DO: Consider using database-level pagination\n",[1050,7924,7925],{"class":1052,"line":1252},[1050,7926,1122],{"emptyLinePlaceholder":1121},[1050,7928,7929],{"class":1052,"line":1288},[1050,7930,7931],{"class":1128},"# Example of optimized query for large datasets\n",[1050,7933,7934,7936,7939,7941,7943,7945,7947],{"class":1052,"line":1309},[1050,7935,4912],{"class":3161},[1050,7937,7938],{"class":4915}," get_recent_posts_optimized",[1050,7940,1221],{"class":1064},[1050,7942,7675],{"class":4921},[1050,7944,1138],{"class":1214},[1050,7946,5663],{"class":1229},[1050,7948,4946],{"class":1064},[1050,7950,7951,7953,7956],{"class":1052,"line":1346},[1050,7952,4952],{"class":4951},[1050,7954,7955],{"class":4955},"Optimized query for recent posts",[1050,7957,4959],{"class":4951},[1050,7959,7960],{"class":1052,"line":1351},[1050,7961,4964],{"class":1060},[1050,7963,7964,7966,7968,7970,7972,7974,7976,7978,7980,7982,7984,7986],{"class":1052,"line":1357},[1050,7965,5182],{"class":1056},[1050,7967,1141],{"class":1060},[1050,7969,1065],{"class":1064},[1050,7971,1147],{"class":1146},[1050,7973,1065],{"class":1064},[1050,7975,7709],{"class":1152},[1050,7977,1221],{"class":1064},[1050,7979,1169],{"class":1168},[1050,7981,5019],{"class":1172},[1050,7983,1169],{"class":1168},[1050,7985,1282],{"class":1064},[1050,7987,1285],{"class":1064},[1050,7989,7990,7992,7994,7996,7998,8000,8002,8004,8006,8008,8010,8012,8014,8016,8018,8020,8022,8024,8026,8028],{"class":1052,"line":1392},[1050,7991,7734],{"class":1064},[1050,7993,7779],{"class":1152},[1050,7995,1221],{"class":1064},[1050,7997,1169],{"class":1168},[1050,7999,3972],{"class":1172},[1050,8001,1169],{"class":1168},[1050,8003,1082],{"class":1064},[1050,8005,3008],{"class":1168},[1050,8007,7794],{"class":1172},[1050,8009,1169],{"class":1168},[1050,8011,1082],{"class":1064},[1050,8013,3008],{"class":1168},[1050,8015,3886],{"class":1172},[1050,8017,1169],{"class":1168},[1050,8019,1082],{"class":1064},[1050,8021,3008],{"class":1168},[1050,8023,3296],{"class":1172},[1050,8025,1169],{"class":1168},[1050,8027,1282],{"class":1064},[1050,8029,1285],{"class":1064},[1050,8031,8032,8034,8036,8038,8040,8042,8044,8046,8048,8050],{"class":1052,"line":1415},[1050,8033,7734],{"class":1064},[1050,8035,1153],{"class":1152},[1050,8037,1221],{"class":1064},[1050,8039,1271],{"class":1162},[1050,8041,1138],{"class":1064},[1050,8043,1169],{"class":1168},[1050,8045,1173],{"class":1172},[1050,8047,1169],{"class":1168},[1050,8049,1282],{"class":1064},[1050,8051,1285],{"class":1064},[1050,8053,8054,8056,8058,8060,8062,8064,8066,8068,8070],{"class":1052,"line":1420},[1050,8055,7734],{"class":1064},[1050,8057,3879],{"class":1152},[1050,8059,1221],{"class":1064},[1050,8061,1169],{"class":1168},[1050,8063,3916],{"class":1172},[1050,8065,1169],{"class":1168},[1050,8067,5856],{"class":1064},[1050,8069,7675],{"class":1060},[1050,8071,2952],{"class":1064},[1050,8073,8074],{"class":1052,"line":1426},[1050,8075,1122],{"emptyLinePlaceholder":1121},[1050,8077,8078],{"class":1052,"line":1459},[1050,8079,8080],{"class":1128},"# Index recommendations for the above query:\n",[1050,8082,8083],{"class":1052,"line":1482},[1050,8084,8085],{"class":1128},"# CREATE INDEX idx_post_status_created ON blog_post(status, created_at DESC);\n",[1050,8087,8088],{"class":1052,"line":1487},[1050,8089,8090],{"class":1128},"# CREATE INDEX idx_author_name ON auth_user(first_name, last_name);\n",[1026,8092,8093],{},"Mastering filtering, ordering, and slicing techniques enables you to build efficient, scalable applications that can handle large datasets while providing excellent user experience through proper pagination and search functionality.",[8095,8096,8097],"style",{},"html pre.shiki code .siDh9, html code.shiki .siDh9{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#1E754F;--shiki-default-font-style:inherit;--shiki-dark:#4D9375;--shiki-dark-font-style:inherit}html pre.shiki code .sftqT, html code.shiki .sftqT{--shiki-light:#90A4AE;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .soVBu, html code.shiki .soVBu{--shiki-light:#39ADB5;--shiki-default:#999999;--shiki-dark:#666666}html pre.shiki code .s9Tkl, html code.shiki .s9Tkl{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#A0ADA0;--shiki-default-font-style:inherit;--shiki-dark:#758575DD;--shiki-dark-font-style:inherit}html pre.shiki code .sBPpx, html code.shiki .sBPpx{--shiki-light:#E53935;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .siWMO, html code.shiki .siWMO{--shiki-light:#6182B8;--shiki-default:#393A34;--shiki-dark:#DBD7CAEE}html pre.shiki code .sqOPj, html code.shiki .sqOPj{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B07D48;--shiki-default-font-style:inherit;--shiki-dark:#BD976A;--shiki-dark-font-style:inherit}html pre.shiki code .sbYkP, html code.shiki .sbYkP{--shiki-light:#39ADB5;--shiki-default:#B5695977;--shiki-dark:#C98A7D77}html pre.shiki code .sTbE_, html code.shiki .sTbE_{--shiki-light:#91B859;--shiki-default:#B56959;--shiki-dark:#C98A7D}html pre.shiki code .s8XtY, html code.shiki .s8XtY{--shiki-light:#39ADB5;--shiki-default:#1E754F;--shiki-dark:#4D9375}html pre.shiki code .sVsLi, html code.shiki .sVsLi{--shiki-light:#39ADB5;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .s7CZa, html code.shiki .s7CZa{--shiki-light:#F76D47;--shiki-default:#2F798A;--shiki-dark:#4C9A91}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s5Kfy, html code.shiki .s5Kfy{--shiki-light:#9C3EDA;--shiki-default:#AB5959;--shiki-dark:#CB7676}html pre.shiki code .sRJPX, html code.shiki .sRJPX{--shiki-light:#91B859;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .s27EL, html code.shiki .s27EL{--shiki-light:#91B859;--shiki-default:#AB5E3F;--shiki-dark:#C4704F}html pre.shiki code .sljsM, html code.shiki .sljsM{--shiki-light:#6182B8;--shiki-default:#59873A;--shiki-dark:#80A665}html pre.shiki code .sCyAa, html code.shiki .sCyAa{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#393A34;--shiki-default-font-style:inherit;--shiki-dark:#DBD7CAEE;--shiki-dark-font-style:inherit}html pre.shiki code .sm7ve, html code.shiki .sm7ve{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#B5695977;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D77;--shiki-dark-font-style:inherit}html pre.shiki code .sVyVU, html code.shiki .sVyVU{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#B56959;--shiki-default-font-style:inherit;--shiki-dark:#C98A7D;--shiki-dark-font-style:inherit}html pre.shiki code .s3h35, html code.shiki .s3h35{--shiki-light:#F76D47;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sFGJz, html code.shiki .sFGJz{--shiki-light:#E53935;--shiki-default:#A65E2B;--shiki-dark:#C99076}html pre.shiki code .sa2tF, html code.shiki .sa2tF{--shiki-light:#E2931D;--shiki-default:#998418;--shiki-dark:#B8A965}html pre.shiki code .sJdAF, html code.shiki .sJdAF{--shiki-light:#6182B8;--shiki-default:#998418;--shiki-dark:#B8A965}",{"title":1045,"searchDepth":1053,"depth":1088,"links":8099},[8100,8105,8110],{"id":1032,"depth":1088,"text":1033,"children":8101},[8102,8103,8104],{"id":1037,"depth":1105,"text":1038},{"id":1794,"depth":1105,"text":1795},{"id":3264,"depth":1105,"text":3265},{"id":3847,"depth":1088,"text":3848,"children":8106},[8107,8108,8109],{"id":3851,"depth":1105,"text":3852},{"id":4136,"depth":1105,"text":4137},{"id":4901,"depth":1105,"text":4902},{"id":5589,"depth":1088,"text":5590,"children":8111},[8112,8113,8114,8115],{"id":5593,"depth":1105,"text":5594},{"id":5863,"depth":1105,"text":5864},{"id":7029,"depth":1105,"text":7030},{"id":7859,"depth":1105,"text":7860},"md",null,{},{"title":280,"description":1028},"n-9v37rpiC1MtADlIBKVK9a7y1lw7uk53LZNqAXUxZo",[8122,8124],{"title":276,"path":277,"stem":278,"description":8123,"children":-1},"Django's ORM provides a powerful and intuitive API for querying your database. Understanding how to construct efficient queries is essential for building performant applications.",{"title":284,"path":285,"stem":286,"description":8125,"children":-1},"Django's Manager and QuerySet system provides a powerful abstraction for database operations. Understanding how to create custom managers and querysets enables you to build reusable, chainable query logic that keeps your code DRY and maintainable.",1772474918431]