Django : 장고 tutorial 앱 작성하기 4단계

Jinsung·2021년 11월 11일
0
post-custom-banner

Model

models.py 모듈 안에 하나 이상의 모델 클래스를 정의할 수 있으며, 하나의 모델 클래스는 데이타베이스에서 하나의 테이블에 해당된다.

모델 클래스는 필드를 정의하기 위해 인스턴스 변수가 아닌 클래스 변수를 사용하는데, 이는 그 변수가 테이블 컬럼의 내용을 갖는 것이 아니라, 테이블의 컬럼 메타 데이타를 정의하는 것이기 때문이다. 필드를 정의하는 각각의 클래스 변수는 models.CharField(), models,IntegerField(), models.DateTimeField(), models.TextField() 등의 각 필드 타입에 맞는 Field 클래스 객체를 생성하여 할당한다.

필드 타입

  • CharField : 제한된 문자열 필드 타입. 최대 길이를 max_length 옵션에 지정해야 한다
  • EmailField : 이메일 주소
  • FilePathField : 특정 폴더의 파일 패스를 표현
  • URLField : URL을 표현
  • TextField : 대용량 문자열을 갖는 필드
  • IntegerField : 32 비트 정수형 필드. 정수 사이즈에 따라 BigIntegerField, SmallIntegerField 을 사용할 수도 있다.
  • BooleanField : true/false 필드. Null 을 허용하기 위해서는 NullBooleanField를 사용한다.
  • DateTimeField : 날짜와 시간을 갖는 필드. 날짜만 가질 경우는 DateField, 시간만 가질 경우는 TimeField를 사용한다.
  • DecimalField : 소숫점을 갖는 decimal 필드
  • BinaryField : 바이너리 데이타를 저장하는 필드
  • FileField : 파일 업로드 필드
  • ImageField : FileField의 파생클래스로서 이미지 파일인지 체크한다.
  • UUIDField : GUID (UUID)를 저장하는 필드

이외에, Django 프레임워크는 테이블 간 혹은 필드 간 관계(Relationship)을 표현하기 위해 ForeignKey, ManyToManyField, OneToOneField 클래스를 또한 제공하고 있다. 특히 ForeignKey는 모델 클래스간 (혹은 Underlying 테이블 간) Many-To-One (혹은 One-To-Many) 관계를 표현하기 위해 흔히 사용된다.

필드 옵션

  • null (Field.null) : null=True 이면, Empty 값을 DB에 NULL로 저장한다. DB에서 Null이 허용된다.
  • blank (Field.blank) : blank=False 이면, 필드가 Required 필드이다. blank=True 이면, Optional 필드이다. 예: models.DateTimeField(blank=True)
  • primary_key (Field.primary_key) : 해당 필드가 Primary Key임을 표시한다
  • unique (Field.unique) : 해당 필드가 테이블에서 Unique함을 표시한다. 해당 컬럼에 대해 Unique Index를 생성한다.
  • default (Field.default) : 필드의 디폴트값을 지정한다. 예: models.CharField(max_length=2, default="WA")
  • db_column (Field.db_column) : 컬럼명은 디폴트로 필드명을 사용하는데, 만약 다르게 쓸 경우 지정한다.

다시 돌아와서 Question class와 Choice class 를 생성

from django.db import models


class Question(models.Model):
    question_text = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')


class Choice(models.Model):
    question = models.ForeignKey(Question, on_delete=models.CASCADE)
    choice_text = models.CharField(max_length=200)
    votes = models.IntegerField(default=0)

모델 활성화 시키기

mysite/settings.py에 INSTALLED_APPS에 설정을 추가

INSTALLED_APPS = [
    'polls.apps.PollsConfig', # 어플명인 polls로 적어도 된다.
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

설정을 추가 한후 밑에 명령어로 모델을 변경시킨 사실과 새로 테이블을 만들었다는걸 migration으로 저장 시킨다.(파일 생성)

python manage.py makemigrations polls

밑에 명령어로 결과물(저장 파일 확인)

python manage.py sqlmigrate polls 0001

migrate를 실행시켜 데이터베이스 모델과 관련된 테이블을 생성 (DB에 전달하여 생성)

python manage.py migrate
post-custom-banner

0개의 댓글