drf-tutorial

dooh kim·2020년 4월 3일
0

drf-tutorial

목록 보기
1/1

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']),
        ]

profile
testify to the light

0개의 댓글