작성자 없음
작성자 정보가 삭제된 글입니다.
작성
·
12
·
수정됨
0
db.users.find({age: {$lt:30, $gt:40}})
안녕하세요
강의 9분쯤 사용하신 이 구문이 작동되지 않아서 ai에게 물어보니 틀린 문법이라고 $or 를 사용하라고 합니다.
그런데 선생님 화면에는 잘 출력이 되어서 여쭤봅니다.
어떤게 맞는건가요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 전해용님.
질문하신 MongoDB 구문에 대한 답변을 드리겠습니다.
MongoDB에서 find
메서드를 사용할 때 조건을 설정하는 방법에서 약간의 오해가 있는 것 같습니다. MongoDB는 \(lt와 \)gt 조건을 동시에 같은 필드에 사용하여 하나의 문서에서 두 조건 모두 만족시키는 데이터는 찾을 수 없습니다. db.users.find({age: {$lt:30, $gt:40}})
구문은 아래와 같은 의미로 해석되며, 실제로 만족할 수 있는 데이터가 없게 됩니다.
이럴 경우, 특정 데이터가 30 미만이거나 40 초과일 때 결과를 얻기 위해서는 $or
연산자를 사용해야 합니다. $or
연산자를 통해 두 조건이 모두 적용되도록 명령어를 작성하셔야 합니다:
db.users.find({ $or: [{ age: { $lt: 30 } }, { age: { $gt: 40 } }] });
위와 같은 수정된 구문을 사용하시면 각각의 조건을 만족하는 데이터를 개별적으로 조회할 수 있습니다.
관련 답변을 찾는 데 도움이 될 만한 링크도 추가하니, 참고하시기 바랍니다:
- 05:45 { ‘$lt’ : 10000 } 에 대하여
- 비교문법 실습 1번
참고로, 쌍따옴표는 JSON 데이터 형식에서 사용되지만 Mongo Shell에서는 없어도 문법상 문제는 없지만 일관성을 유지하는 것이 좋습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.