Django 쿼리 - id vs pk

2024-07-27

Django ORM에서 idpk는 모두 동일한 값을 참조하는 데 사용되는 약어이지만, 약간의 차이점이 있습니다.

id는 Django가 자동으로 생성하는 데이터베이스 테이블의 각 레코드에 대한 고유 식별자입니다. 일반적으로 AutoField 필드를 사용하여 생성됩니다. idint 형식이며, 테이블 내에서 레코드를 식별하는 데 사용됩니다.

pkprimary key의 약어이며, 테이블 내에서 레코드를 고유하게 식별하는 데 사용되는 하나 이상의 필드를 나타냅니다. pkid와 동일한 값을 가질 수도 있지만, 여러 필드로 구성된 복합 키일 수도 있습니다.

예시:

class Book(models.Model):
    title = models.CharField(max_length=255)
    author = models.ForeignKey(Author, on_delete=models.CASCADE)
    publication_date = models.DateField()

이 예시에서 Book 모델은 id 필드를 가지고 있으며, 이 필드는 자동으로 생성된 고유 식별자입니다. 또한 Book 모델은 author 필드를 가지고 있으며, 이 필드는 Author 모델의 외래 키입니다. author 필드는 Book 모델의 레코드를 고유하게 식별하는 데 사용될 수 있는 pk로 간주될 수 있습니다.

일반적으로 다음과 같은 경우에 pk를 사용하는 것이 좋습니다:

  • 테이블 내에서 특정 레코드를 참조해야 할 때
  • 쿼리에서 여러 테이블을 조인해야 할 때
  • 객체를 삭제하거나 업데이트해야 할 때

id는 다음과 같은 경우에 사용하는 것이 좋습니다:**

  • 테이블 내에서 레코드의 순서를 나타내야 할 때
  • 객체를 생성할 때

요약:

  • id는 Django가 자동으로 생성하는 고유 식별자입니다.
  • pk는 테이블 내에서 레코드를 고유하게 식별하는 데 사용되는 하나 이상의 필드를 나타냅니다.
  • 일반적으로 pk를 사용하는 것이 좋습니다.
  • id는 특정 상황에서 사용하는 것이 좋습니다.



Django 쿼리 - id vs pk 예제 코드

예제 1: 특정 레코드 참조하기

book = Book.objects.get(pk=1)
print(book.title)  # "The Lord of the Rings" 출력

이 예시에서는 pk를 사용하여 Book 모델의 ID가 1인 레코드를 가져옵니다.

예제 2: 쿼리에서 여러 테이블 조인하기

author = Author.objects.get(name="J.R.R. Tolkien")
books = author.book_set.all()
for book in books:
    print(book.title)

이 예시에서는 pk를 사용하여 Author 모델의 이름이 "J.R.R. Tolkien"인 레코드를 가져옵니다. 그런 다음 book_set 관계를 사용하여 해당 저자의 모든 책을 가져옵니다.

예제 3: 객체 삭제하기

book = Book.objects.get(pk=1)
book.delete()

예제 4: 객체 업데이트하기

book = Book.objects.get(pk=1)
book.title = "The Hobbit"
book.save()

이 예시에서는 pk를 사용하여 Book 모델의 ID가 1인 레코드를 가져옵니다. 그런 다음 title 필드를 "The Hobbit"으로 업데이트하고 변경 사항을 저장합니다.

예제 5: 테이블 내에서 레코드 순서 나타내기

books = Book.objects.order_by('id')
for book in books:
    print(book.title)

이 예시에서는 id를 사용하여 Book 모델의 모든 레코드를 ID 순서대로 가져옵니다.

book = Book(title="The Silmarillion", author=author)
book.save()

이 예시에서는 id가 자동으로 생성되는 Book 모델의 새 레코드를 만듭니다.

  • 이 예제 코드는 Django ORM의 기본적인 기능만 보여줍니다. Django ORM에는 더 많은 기능이 있습니다.



Django 쿼리 - id 대신 pk를 사용하는 대체 방법

id를 사용하는 대체 방법:

  • get_by_natural_key() 메서드 사용: 일부 모델은 get_by_natural_key() 메서드를 제공합니다. 이 메서드는 모델의 고유 식별자를 식별하는 데 사용되는 하나 이상의 필드를 사용하여 레코드를 가져옵니다. 예를 들어 다음과 같이 사용할 수 있습니다.
book = Book.objects.get_by_natural_key(title="The Lord of the Rings")
print(book.title)  # "The Lord of the Rings" 출력
  • filter() 메서드 사용: filter() 메서드를 사용하여 id 필드를 기준으로 레코드를 필터링할 수 있습니다. 예를 들어 다음과 같이 사용할 수 있습니다.
books = Book.objects.filter(id=1)
for book in books:
    print(book.title)  # "The Lord of the Rings" 출력

주의 사항:

  • id를 사용하는 것은 일반적으로 권장되지 않습니다. id는 테이블 내에서 레코드의 순서를 나타내는 데 사용되며, 이 순서는 변경될 수 있습니다. pk는 테이블 내에서 레코드를 고유하게 식별하는 데 사용되는 하나 이상의 필드로 구성되며, 이 필드는 변경되지 않습니다.
  • id를 사용하면 쿼리가 느려질 수 있습니다. Django는 pk를 사용하여 테이블 내에서 레코드를 빠르게 찾을 수 있지만, id를 사용하면 테이블 전체를 검색해야 할 수도 있습니다.
  • 일부 특수한 경우에는 id를 사용하는 것이 더 적합할 수 있습니다.
  • id를 사용하기 전에 주의 사항을 확인하십시오.

django orm primary-key



Django 사용자 지정 폼에서 시간/날짜 위젯 사용

1. 위젯 선택Django는 다양한 시간/날짜 위젯을 제공합니다. 가장 일반적으로 사용되는 위젯은 다음과 같습니다.SelectDateWidget: 드롭다운 메뉴를 사용하여 날짜를 선택할 수 있습니다.SelectTimeWidget: 드롭다운 메뉴를 사용하여 시간을 선택할 수 있습니다...


Django에서 URL 생성 방법

1. urls. py 파일 사용:Django 프로젝트의 urls. py 파일은 URL 패턴을 정의하는 데 사용됩니다. 각 패턴은 URL과 요청을 처리할 뷰 함수를 연결합니다. 기본적인 URL 패턴은 다음과 같습니다...


Django에서 User 모델을 확장하는 가장 좋은 방법

Django에서 User 모델을 확장하는 방법은 여러 가지가 있습니다.1. 프로필 모델 사용가장 일반적인 방법은 프로필 모델을 사용하는 것입니다. 프로필 모델은 User 모델과 일대일 관계를 갖는 별도의 모델입니다...


대규모 Django 프로젝트를 위한 프로젝트 설계 및 파일 시스템 레이아웃

프로젝트 설계Django 프로젝트를 위한 일반적인 프로젝트 설계에는 다음과 같은 몇 가지 주요 구성 요소가 포함됩니다.루트 프로젝트 디렉토리: 이 디렉토리는 프로젝트의 모든 주요 구성 요소를 포함합니다. 일반적으로 project_name이라는 이름을 갖습니다...


Django 세션 프로그래밍 (Python, Django)

Django 세션은 웹사이트 방문자의 상태를 추적하는 데 사용되는 강력한 도구입니다. 로그인 상태, 쇼핑 카트 항목, 사용자 선호도와 같은 정보를 저장하는 데 사용할 수 있습니다. 세션은 쿠키를 사용하여 클라이언트 측에서 저장되므로 여러 페이지를 방문하더라도 정보가 유지됩니다...



django orm primary key

Django 클래스 뷰 프로그래밍 개요 (Python, Django, View)

클래스 뷰는 다음과 같은 장점을 제공합니다.코드 재사용성 향상: 공통 로직을 한 번 작성하고 상속을 통해 여러 뷰에서 재사용할 수 있습니다.코드 가독성 향상: 뷰 로직이 명확하게 구분되어 코드를 이해하기 쉽습니다.유지 관리 용이성 향상: 코드 변경이 필요할 경우 한 곳만 변경하면 모든 관련 뷰에 영향을 미칠 수 있습니다


Django 모델에서 MySQL ENUM 유형 필드를 지정하는 방법

1. 필요한 모듈 가져오기:2. ENUM 선택 목록 정의:3. 모델 클래스 정의:설명:MY_ENUM_CHOICES 튜플은 유효한 ENUM 값 목록을 정의합니다. 각 튜플 요소는 값과 해당 값의 표시 문자열로 구성됩니다


Django를 위한 최신 및 빠른 서버 설정 (Python, Django, Apache 활용)

본 가이드에서는 Python, Django, Apache를 사용하여 Django 웹 애플리케이션을 위한 최신かつ 빠른 서버 설정 방법을 단계별로 안내합니다. 이 설정은 성능, 확장성 및 보안을 위해 최적화되어 있으며


Django 템플릿을 사용하여 트리 구조(재귀적)를 렌더링하는 방법

1. 재귀 템플릿 사용이 방법은 트리 구조를 재귀적으로 탐색하고 각 노드에 대한 템플릿을 렌더링하는 데 기반합니다. 다음은 재귀 템플릿을 사용하여 트리 구조를 렌더링하는 방법의 예입니다.이 예에서는 tree. html 템플릿은 각 노드의 이름과 자식 노드가 있는 경우 자식 노드 목록을 렌더링합니다


Django 템플릿 및 변수 속성 (Python, Django, Google App Engine)

템플릿 변수는 템플릿에서 값을 표시하는 데 사용되는 특수 문자입니다. 템플릿 변수는 다음과 같이 {{ }} 로 표시됩니다.예를 들어, 다음 템플릿은 "Hello, John!"라는 문자열을 출력합니다.여기서 name은 템플릿에 전달된 변수 이름입니다