Home Django 모델 (ORM)
Post
Cancel

Django 모델 (ORM)

인프런 파이썬/장고 웹서비스 개발 완벽 가이드 with 리액트 강의를 보고 정리한 내용입니다.


강의 내용 정리

강의명 : 파이썬/장고 웹서비스 개발 완벽 가이드 with 리액트

강의: 장고 ORM


데이터베이스와 SQL

SQL: 데이터베이스에 쿼리하기 위한 언어

직접 SQL을 만들어내기도 하지만, ORM (Object-relational mapping)을 통해 SQL을 생성/실행하기도 한다.

ORM을 쓰더라도, 작성한 ORM코드를 통해 어떤 SQL이 실행되고 있는지 파악을 해야 최적화 가능

  • django-debug-toolbar 적극 활용

장고 ORM인 모델은 RDB만을 지원

다양한 파이썬 ORM

Rleational Databases

  • django databases, sqlalchemy, orator, peewee, ponyORM 등

NoSQL Databases

  • django-mongodb-engine, hot-redis, MongoEngine, PynamoDB 등

장고의 강점은 Model과 Form

물론 장고에서도 다양한 ORM 라이브러리를 사용 가능. 적절하게 섞어쓸 수 있음

SQL을 직접 실행할 수도 있지만, 간으하면 ORM tkdyd

  • 직접 SQL문자열을 조합하지 말고, 인자로 처리 → SQL Injection 방지
    • SQL Injection이란 악의적인 사용자가 특정 SQL 쿼리 문을 전송하여 서버 DB를 공격하는 해킹 기법

Django Model

데이터베이스 테이블과 파이썬 클래스를 1:1로 매핑

모델 클래스명은 단수형으로 지정 ex: Posts (x), Post (O)

  • 클래스이기에 필히 첫 글자가 대문자인 PascalCase 네이밍

매핑되는 모델 클래스는 DB 테이블 필드내역이 일치해야 함

모델을 만들기 전에 서비스에 맞게 데이터베이스 설계가 필수

  • 즉 관계형 데이터베이스 학습도 필요 (DB의 영역은 또 다름 )

앱 폴더에 있는 models.py 파일에 아래처럼 작성하게 됨

모델 활용 순서

  • 장고 모델을 만들고, 데이터 베이스 형상 관리
    1. 모델 클래스 작성
    2. 모델 클래스로부터 마이그레이션 파일 생성 → makemigrations 명령
    3. 마이그레이션 파일을 데이터베이스에 적용 → migrate 명령
    4. 모델 활용
  • 기존 외부 DB를 현재 데이터베이스로 가져와서 형상 관리
    1. 데이터베이스로부터 모델 클래스 소스 생성 → Inspectdb 명령
    2. 모델 활용

모델명과 DB 테이블명

DB 테이블명: 디폴트 “앱이름_모델명”

ex.

blog앱

  • Post 모델: blog_post
  • Comment 모델: blog_comment

shot 앱

  • Item 모델: shot_item
  • review 모델: shop_review

적용순서

Item 모델 정의

마이그레이션 파일 생성

1
python3 manage.py makemigrations 앱이름

마이그레이션 파일 적용

1
python3 manage.py migrate

데이터베이스 확인

1
2
#sqllite가 생성되어 있다면
python3 manage.py dbshell

위 순서대로 모델 만들어서 적용해보기

앱 등록

인스타그램 이라는 이름의 앱 생성

1
python3 manage.py startapp instagram

settings.py에 앱 이름 추가

1
2
3
4
5
6
7
8
9
10
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'blog',
    'instagram',
]

urls.py 직접 추가

안에 다음과 같이 입력

1
urlpatterns = []

프로젝트 디렉토리 urls.py에 다음 한 줄 추가

모델 생성

instagram 디렉토리 models.py에 다음과 같이 모델 생성

1
2
3
4
5
6
7
from django.db import models

# Create your models here.
class Post(models.Model):
    message = models.Textfield()
    created_at = models.DateTimeField(auto_now_add=True)
    updated_at = models.DateTimeField(auto_now=True)

마이그레이션 파일 적용

1
python3 manage.py makemigrations instagram

오타가 있거나 하면 다음과 같은 에러가 남

1
AttributeError: module 'django.db.models' has no attribute 'Textfield'

혹은 settings.py에 앱을 추가안해주었거나, 추가해주고 저장을 안해주었다면 다음과 같은 에러

1
No installed app with label 'instagram'.

성공하면 다음과 같이 뜸

1
2
3
Migrations for 'instagram':
  instagram/migrations/0001_initial.py
    - Create model Post

마이그레이션 파일 적용

다음 명령어 입력

1
python3 manage.py migrate instagram

아래와 같이 뜨면 models.py에 작성한대로 Post라는 테이블이 생성이 된 것

1
2
3
4
Operations to perform:
  Apply all migrations: instagram
Running migrations:
  Applying instagram.0001_initial... OK

데이터베이스에 들어간 코드 확인

1
python3 manage.py sqlmigrate instagram 0001_initial

아래와 같은 명령어가 입력된 것을 알 수 있음 (id는 따로 지정안해주었지만 primary key로 자동 생성되어씅ㅁ)

1
2
3
4
5
6
BEGIN;
--
-- Create model Post
--
CREATE TABLE "instagram_post" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "message" text NOT NULL, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL);
COMMIT;
This post is licensed under CC BY 4.0 by the author.