snippets.objects.all()
불러올 때마다 정렬을 해서 가지고 온다.
https://www.django-rest-framework.org/tutorial/quickstart/
class Meta:
ordering = ['create']
비싼 연산을 하는 것이다.
DB에 index를 지정한다는 것은
미리 이전에 index 테이블을 만들어서 정렬 순서대로 index를 지정해 놨다가
그 순서로 저장된 테이블에서 바로 가져오는 것이다.
가져올 때마다 정렬하는게 아니고
미리 저장해 놨다가 그대로 가져오는 거다
relatedFiedl -> index (관계도 잡힌 필드는 인데스 정렬 해놓는다.)
foreignkey
manytomany
onetoone
일반 field는 인덱스 넣어줘야한다.
Meta에다가 넣는게 django에서 권장하는 방법
from django.db import models
# Create your models here.
from django.db import models
from pygments.lexers import get_all_lexers
from pygments.styles import get_all_styles
LEXERS = [item for item in get_all_lexers() if item[1]]
LANGUAGE_CHOICES = sorted([(item[1][0], item[0]) for item in LEXERS])
STYLE_CHOICES = sorted([(item, item) for item in get_all_styles()])
class Snippet(models.Model):
# DB index설정 (feild.DB)
created = models.DateTimeField(auto_now_add=True)
title = models.CharField(max_length=100, blank=True, default='')
code = models.TextField()
linenos = models.BooleanField(default=False)
language = models.CharField(choices=LANGUAGE_CHOICES, default='python', max_length=100)
style = models.CharField(choices=STYLE_CHOICES, default='friendly', max_length=100)
class Meta:
# queryset으로 불러올 때 정렬해서 가져
# 우리는 created 기준으로 정렬되어있다는 거 알고 있지만
# django는 모르기 때문에 재정렬 되어 날아온다.
ordering = ['created']
# DB index설정 (Model.Meta)
indexes = [
models.Index(fields=['created']),
]