MongoDB -投影
안녕하세요, 미래의 데이터베이스 마법사 여러분! 오늘 우리는 MongoDB 프로젝션의 fascinatings한 세상으로 뛰어들어 볼 거예요. 프로그래밍에 처음이라고 걱정하지 마세요 - 저는 이 개념을 단계별로 안내해 드릴게요. 수년 동안 수많은 학생들을 가르친 경험을 바탕으로 말이죠. 그럼 여러분의 최爱 음료를 한 잔 들고, 이 흥미로운 여정에 함께 동행해 주세요!
MongoDB에서의 Projection은 무엇인가요?
자, 구체적인 내용으로 들어가기 전에 MongoDB에서 프로젝션은 무엇을 의미하는지 이해해 보겠습니다. 대규모 도서관(데이터베이스)에 수천권의 책(도큐メント)이 있다고 상상해 보세요. 그런데 이 책들의 제목만 알고 싶어서 책 전체를 들고 다니기는 귀찮다면 어떨까요? MongoDB에서 프로젝션은 바로 이런 일을 합니다 - 필요한 특정 필드만 도큐먼트에서 검색할 수 있게 해줍니다.
find() 메서드
MongoDB 쿼리의 핵심은 find()
메서드입니다. 이 작은 강력한 도구를 사용하여 콜렉션에서 도큐먼트를 검색합니다. 하지만 프로젝션과 함께 사용하면 더욱 강력해집니다. 어떻게 보겠습니다!
기본 문법
find()
메서드와 프로젝션을 사용한 기본 문법은 다음과 같습니다:
db.collection.find(query, projection)
여기서 query
는 반환할 도큐먼트를 지정하고, projection
은 그 도큐먼트에서 반환할 필드를 지정합니다.
필드 포함
간단한 예제로 시작해 보겠습니다. 학생들의 콜렉션이 있고, 이름과 나이만 반환하고 싶다고 가정해 봅시다. 이렇게 합니다:
db.students.find({}, { name: 1, age: 1 })
이 예제에서:
- 첫 번째
{}
는 빈 쿼리로, 모든 도큐먼트를 의미합니다. -
{ name: 1, age: 1 }
은 우리의 프로젝션입니다.1
은 이 필드를 포함하려는 뜻입니다.
이 쿼리는 다음과 같은 결과를 반환합니다:
[
{ "_id": ObjectId("..."), "name": "Alice", "age": 20 },
{ "_id": ObjectId("..."), "name": "Bob", "age": 22 },
...
]
_id
필드는 기본적으로 항상 포함됩니다. 마치 불청의 손님처럼 항상 나타나죠!
필드 제외
이제 특정 필드를 제외하고 싶다면 어떻게 할까요? 그것도 할 수 있습니다! 예를 들어, 학생의 비밀 슈퍼히어로 신분을 제외하고 싶다면:
db.students.find({}, { superhero_identity: 0 })
여기서 0
은 이 필드를 제외하려는 뜻입니다. 이 쿼리는 superhero_identity
필드를 제외한 모든 필드를 반환합니다.
포함과 제외 혼합
Fun fact: 프로젝션에서 1
과 0
을 혼합할 수 없습니다. _id
필드를 제외하고는 말이죠. 마치 기름과 물을 섞는 것처럼 잘 되지 않습니다! MongoDB는 여러분이 필드를 포함하거나 제외하는 데 명확해야 하기를 바랍니다.
_id 제외
우리의 불청의 손님 _id
를 제외하려면 어떻게 할까요? 이렇게 합니다:
db.students.find({}, { name: 1, age: 1, _id: 0 })
이렇게 하면 이름과 나이만 반환됩니다:
[
{ "name": "Alice", "age": 20 },
{ "name": "Bob", "age": 22 },
...
]
고급 프로젝션 기술
기본적인 내용을 다루고 나서, 이제 더 고급 기술을 살펴보겠습니다. 이 것들은 MongoDB 마법사의 비밀 스펠북에 있는 것들입니다!
내장 문서 프로젝션
각 학생 도큐먼트에 내장된 문서가 주소인 경우, 이 내장 문서의 특정 필드를 프로젝션할 수 있습니다:
db.students.find({}, { "name": 1, "address.city": 1 })
이렇게 하면 학생의 이름과 주소의 도시 필드만 반환됩니다:
[
{ "_id": ObjectId("..."), "name": "Alice", "address": { "city": "Wonderland" } },
{ "_id": ObjectId("..."), "name": "Bob", "address": { "city": "Builderville" } },
...
]
배열 요소 프로젝션
각 학생에 대한 점수 배열이 있고, 첫 두 개의 점수만 원하는 경우, $slice
연산자를 사용할 수 있습니다:
db.students.find({}, { name: 1, scores: { $slice: 2 } })
이렇게 하면 학생의 이름과 첫 두 개의 점수만 반환됩니다:
[
{ "_id": ObjectId("..."), "name": "Alice", "scores": [95, 88] },
{ "_id": ObjectId("..."), "name": "Bob", "scores": [92, 78] },
...
]
프로젝션 메서드 표
이제 배운 프로젝션 메서드를 요약한 표를 보여드리겠습니다:
메서드 | 설명 | 예제 |
---|---|---|
필드 포함 |
1 을 사용하여 특정 필드 포함 |
{ name: 1, age: 1 } |
필드 제외 |
0 을 사용하여 특정 필드 제외 |
{ superhero_identity: 0 } |
_id 제외 |
_id 를 0 으로 설정하여 제외 |
{ name: 1, _id: 0 } |
내장 문서 필드 프로젝션 | 대시 기호를 사용한 점 표기법 | { "address.city": 1 } |
배열 요소 프로젝션 |
$slice 연산자 사용 |
{ scores: { $slice: 2 } } |
결론
그렇습니다, 내 사랑하는 학생 여러분! 우리는 MongoDB 프로젝션의 땅을 여행했습니다. 필드 포함과 제외의 기본 개념에서 내장 문서와 배열 요소에 대한 고급 기술까지. 프로젝션은 데이터베이스 슈퍼마켓에서 선택적인 쇼핑객처럼, 필요한 것만 골라내어 시간과 자원을 절약해줍니다.
이 기술들을 연습하면서, 프로젝션은 MongoDB 도구箱에서 매우 강력한 도구임을 발견하게 될 것입니다. 데이터베이스 연산을 더 효율적으로 만들고, 코드를 깨끗하게 만듭니다.
계속 실험하고, 배우고, 가장 중요한 것은 즐기세요! 발견의 기쁨이 프로그래밍을 이렇게 흥미로운 분야로 만들고 있습니다. 다음에 다시 만날 때까지, 행복하게 코딩하세요!
Credits: Image by storyset