Django

ประสิทธิภาพของ Django

การปรับแต่ง query, ปัญหา N+1, ดัชนีฐานข้อมูล, connection pooling, profiling, monitoring

24 คำถามสัมภาษณ์·
Senior
1

ปัญหาด้านประสิทธิภาพที่พบบ่อยที่สุดที่เกี่ยวข้องกับ query ของ Django ORM คืออะไร?

คำตอบ

ปัญหา N+1 เป็นปัญหาด้านประสิทธิภาพที่พบบ่อยที่สุดของ Django ORM เกิดขึ้นเมื่อ query เริ่มต้นดึงข้อมูล N ออบเจ็กต์ จากนั้นมีการรัน query เพิ่มอีก N ครั้งเพื่อดึงออบเจ็กต์ที่เกี่ยวข้อง ตัวอย่างเช่น การวนซ้ำผ่านบทความและเข้าถึงผู้เขียนของบทความนั้นจะสร้าง query หนึ่งครั้งต่อบทความแทนที่จะเป็น query แบบ join เพียงครั้งเดียว

2

ควรใช้เมธอดใดในการแก้ปัญหา N+1 กับความสัมพันธ์แบบ ForeignKey?

คำตอบ

select_related() เป็นเมธอดที่เหมาะสมในการแก้ปัญหา N+1 กับความสัมพันธ์ ForeignKey และ OneToOneField โดยจะทำการ join SQL และดึงออบเจ็กต์ที่เกี่ยวข้องในครั้งเดียว ส่วน prefetch_related() ใช้สำหรับความสัมพันธ์ ManyToMany หรือความสัมพันธ์แบบย้อนกลับ (ForeignKey reverse)

3

ควรใช้ prefetch_related() แทน select_related() เมื่อใด?

คำตอบ

prefetch_related() ออกแบบมาสำหรับความสัมพันธ์ ManyToMany และความสัมพันธ์แบบย้อนกลับ (ForeignKey reverse) ต่างจาก select_related() ที่ทำ join SQL prefetch_related() จะรัน query แยกและทำการ join ใน Python ซึ่งหลีกเลี่ยงการซ้ำซ้อนของข้อมูลที่จะเกิดขึ้นกับการ join SQL บนความสัมพันธ์ many-to-many

4

จะใช้ Prefetch() เพื่อปรับแต่ง query ของ prefetch_related() อย่างไร?

5

ประโยชน์หลักของการเพิ่มดัชนีฐานข้อมูลบนฟิลด์คืออะไร?

+21 คำถามสัมภาษณ์

หัวข้อสัมภาษณ์ Django อื่นๆ

พื้นฐาน Python

Junior
25 คำถาม

Python เชิงวัตถุ

Junior
20 คำถาม

พื้นฐาน Django

Junior
20 คำถาม

Django Models - พื้นฐาน

Junior
22 คำถาม

Django Views

Junior
20 คำถาม

เทมเพลต Django

Junior
18 คำถาม

ฟอร์ม Django

Mid-Level
22 คำถาม

QuerySets ขั้นสูง

Mid-Level
25 คำถาม

การยืนยันตัวตนใน Django

Mid-Level
22 คำถาม

Django Middleware

Mid-Level
18 คำถาม

Django Admin

Mid-Level
20 คำถาม

Django REST Framework

Mid-Level
30 คำถาม

Django Signals

Mid-Level
18 คำถาม

การอัปโหลดไฟล์

Mid-Level
20 คำถาม

การแคชใน Django

Mid-Level
20 คำถาม

Django Sessions

Mid-Level
18 คำถาม

อีเมลใน Django

Mid-Level
18 คำถาม

การทดสอบ Django

Mid-Level
22 คำถาม

ความปลอดภัยของ Django

Mid-Level
22 คำถาม

การ Deploy Django

Mid-Level
24 คำถาม

Django ORM ขั้นสูง

Senior
28 คำถาม

Django & Celery

Senior
22 คำถาม

Django Channels

Senior
24 คำถาม

Django & GraphQL

Senior
24 คำถาม

Django & Docker

Senior
20 คำถาม

Django ในระบบนิเวศ Microservices

Senior
24 คำถาม

คำสั่ง Django แบบกำหนดเอง

Senior
18 คำถาม

การทำให้รองรับหลายภาษาใน Django

Senior
20 คำถาม

Design Patterns ใน Django

Senior
24 คำถาม

Django Async และ ASGI

Senior
26 คำถาม

Settings และการตั้งค่า Production

Senior
22 คำถาม

Observability และ Monitoring

Senior
24 คำถาม

เชี่ยวชาญ Django สำหรับการสัมภาษณ์ครั้งถัดไป

เข้าถึงคำถามทั้งหมด flashcards แบบทดสอบเทคนิค แบบฝึกหัด code review และตัวจำลองสัมภาษณ์

เริ่มใช้ฟรี