1. Django 모델 API
앞의 Django 모델에서처럼 모델 클래스를 정의하게 되면, Django는 데이타를 추가/갱신하고 읽어 들일 수 있는 다양한 데이타베이스 API 들을 자동으로 제공한다. 이러한 기능은 Django가 ORM 서비스를 기본적으로 제공함에 따른 것으로 데이타베이스를 편리하게 핸들링할 수 있게 도와준다.
2. INSERT
데이타를 삽입하기 위해서는 먼저 테이블에 해당하는 모델(Model Class)로부터 객체를 생성하고, 그 객체의 save() 메서드를 호출하면 된다. 아래 예제는 Feedback() 생성자 안에 필요한 필드 값들을 채운 후 save() 메서드를 호출하는 코드이다. save() 메서드가 호출되면, SQL의 INSERT이 생성되고 실행되어 테이블에 데이타가 추가된다.
from feedback.models import * from datetime import datetime # Feedback 객체 생성 fb = Feedback(name = 'Kim', email = 'kim@test.com', comment='Hi', createDate=datetime.now()) # 새 객체 INSERT fb.save()
3. SELECT
Django는 디폴트로 모든 Django 모델 클래스에 대해 "objects" 라는 Manager (django.db.models.Manager) 객체를 자동으로 추가한다 (이 objects라는 이름을 변경할 수도 있지만, 대부분 그대로 사용한다). Django 에서 제공하는 이 Manager를 통해 특정 데이타를 필터링 할 수도 있고 정렬할 수도 있으며 기타 여러 기능들을 사용할 수 있다.
데이타를 읽어오기 위해서는 Django 모델의 Manager 즉 "모델클래스.objects" 를 사용한다. 예를 들어, Feedback 이라는 모델의 경우 "Feedback.objects" 를 사용한다 (객체명이 아니라 클래스명을 사용함에 주의).
Django Model API에는 기본적으로 제공하는 여러 쿼리 메서드들이 있는데, 여기서는 자주 사용되는 주요 메서드 몇 가지만 살펴보자. (Feedback 모델 클래스를 기준으로 설명)
-
all() : 테이블 데이타를 전부 가져오기 위해서는 Feedback.objects.all() 과 같이 all() 메서드를 사용한다.
다음은 Feedback 테이블의 모든 데이타의 id와 name 컬럼을 출력하는 예이다.
for f in Feedback.objects.all(): s += str(f.id) + ' : ' + f.name + '\n'
-
get() : 하나의 Row만을 가져오기 위해서는 get() 메서드를 사용한다. 예를 들어, 아래는
Primary Key (일반적으로 id 컬럼)가 1인 row를 가져온다.
row = Feedback.objects.get(pk=1) print(row.name)
-
filter() : 특정 조건에 맞는 Row들을 가져오기 위해서는 filter() 메서드를 사용한다. 예를 들어, 아래는
name 필드가 Kim 인 데이타만 가져온다.
rows = Feedback.objects.filter(name='Kim')
-
exclude() : 특정 조건을 제외한 나머지 Row들을 가져오기 위해서는 exclude() 메서드를 사용한다. 예를 들어, 아래는
name 필드가 Kim이 아닌 데이타만 가져온다.
rows = Feedback.objects.exclude(name='Kim')
-
count() : 데이타의 갯수(row 수)를 세기 위해 count() 메서드를 사용한다.
n = Feedback.objects.count()
-
order_by() : 데이타를 키에 따라 정렬하기 위해 order_by() 메서드를 사용한다. order_by() 안에는
정렬 키를 나열할 수 있는데, 앞에 -가 붙으면 내림차순이다. 아래는 id를 기준으로 올림차순, createDate로 내림차순으로
정렬하게 된다.
rows = Feedback.objects.order_by('id', '-createData')
-
distinct() : 중복된 값은 하나로만 표시하기 위해 distinct() 메서드를 사용한다.
SQL의 SELECT DISTINCT 와 같은 효과를 낸다.
아래는 name필드가 중복되는 경우 한번만 표시하게 된다.
rows = Feedback.objects.distinct('name')
-
first() : 데이타들 중 처음에 있는 row만을 리턴한다.
아래는 name필드로 정렬했을 때 처음 row를 리턴한다.
rows = Feedback.objects.order_by('name').first()
-
last() : 데이타들 중 마지막에 있는 row만을 리턴한다.
아래는 name필드로 정렬했을 때 마지막 row를 리턴한다.
rows = Feedback.objects.order_by('name').last()
위의 쿼리 메서드들은 하나 하나가 실제 데이타 결과를 직접 리턴한다기 보다는 쿼리 표현식(Django에서 QuerySet이라 한다)을 리턴하는데, 여러 메서드들을 체인처럼 연결하여 사용할 수 있다. 즉, 여러 체인으로 연결되어 리턴된 쿼리가 해석되어 DB에 실제 하나의 쿼리를 보내게 된다. 아래는 여러 메서드들을 사용하여 체인으로 연결한 예제이다.
row = Feedback.objects.filter(name='Kim').order_by('-id').first()
4. UPDATE
데이타를 수정하기 위해서는 먼저 수정할 Row 객체를 얻은 후 변경할 필드들을 수정한다. 이어 마지막에 save() 메서드를 호출되면, SQL의 UPDATE이 실행되어 테이블에 데이타가 갱신된다. 아래는 id가 1인 Feedback 객체에 이름을 변경하는 코드이다.
fb = Feedback.objects.get(pk=1) fb.name = 'Park' fb.save()
5. DELETE
데이타를 삭제하기 위해서는 먼저 삭제할 Row 객체를 얻은 후 delete() 메서드를 호출하면 된다. 아래는 id가 2인 Feedback 객체를 삭제하는 코드이다.
fb = Feedback.objects.get(pk=2) fb.delete()