강의9분 조건연산자 관련 질문입니다
59
작성자 없음
0 asked
db.users.find({age: {$lt:30, $gt:40}})안녕하세요
강의 9분쯤 사용하신 이 구문이 작동되지 않아서 ai에게 물어보니 틀린 문법이라고 $or 를 사용하라고 합니다.
그런데 선생님 화면에는 잘 출력이 되어서 여쭤봅니다.
어떤게 맞는건가요?
Answer 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에서는 없어도 문법상 문제는 없지만 일관성을 유지하는 것이 좋습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
nosql -> sql 비교
0
29
1
studio 3t 설치시 문의
0
33
1
Compass
0
46
1
강의 자료 1,2,7단원만 뜨고 압축 아무리 풀어도 나오지 않는데
0
64
1
MONGODB_FUNCODING_V1_2 강의자료 에러
0
96
2
애플실리콘(M1) 몽고DB 최초 설치 후 실행 시 에러 Error: Permission denied
0
210
1
db.movies.aggregate() 질문
0
147
1
아나콘다 설치가 어려운데 아나콘다가 꼭 필요 할까요 ?
0
322
1
어그리게이션 프레임웍 질문
0
158
1
studio - 3T에서 Connection오류
0
440
2
db에 이미지 데이터 저장
1
1468
1
stduio 3t 설치 완료후 처음 실행하고 Login진행 시키면 웹 화면에서 계속 멈춰있습니다 더이상 진행도 안됩니다.
1
280
1
몽고DB 비교 문법 출력이 안 됩니다.
0
344
1
아나콘다에서 주피터 노트북이 없습니다
0
461
1
껏다 켜보니 funcoding 데이터베이스가 안보입니다 ㅠ
0
225
1
nosql 섹션3. 몽고DB 데이터 수정하기부분 질문
0
248
1
강의자료가 다 들어 있지 않은 것 같아요.
0
537
3
재귀적 크롤링을 위한 링크 가져오기 8:20
0
311
1
cmd에서 mongod
0
339
1
다른 강의 수강자분들께 도움될까 싶어 남깁니다.(linux mongodb 실행관련)
0
427
1
강의 자료 문서는 제공이 안되나요?
0
438
1
putty 접속 후 몽고db 스타트를 꼭 해야하나요?
0
417
1
안녕하세요 터미널 창에서 이상한 화면 질문드립니다!
0
486
1
no supported authentication methods available (server sent publickey) putty
0
895
1

