정의
$where$where연산자를 사용하여 JavaScript 표현식이 포함된 문자열 또는 전체 JavaScript 함수를 쿼리 시스템으로 전달합니다. #mongodb-query-op.-where는 더 큰 유연성을 제공하지만, 데이터베이스가 컬렉션의 각 문서에 대해 JavaScript 표현식 또는 함수를 처리해야 합니다.this또는obj를 사용하여 JavaScript 표현식 또는 함수에서 문서를 참조합니다.
호환성
다음 환경에서 호스팅되는 배포에 $where 사용할 수 있습니다.
MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스
MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전
MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전
구문
$where 연산자의 형식은 다음과 같습니다.
{ $where: <string|JavaScript Code> }
참고
참고
선호하는 집계 대안
$expr 연산자를 사용하면 쿼리 언어 내에서 집계 표현식을 사용할 수 있습니다. $function 및 $accumulator를 사용하면 제공된 파이프라인 연산자가 애플리케이션의 요구 사항을 충족할 수 없는 경우 사용자가 JavaScript에서 사용자 지정 집계 표현식을 정의할 수 있습니다.
사용 가능한 집계 연산자가 주어집니다.
행동
사용 가능한 JavaScript 속성 및 함수
map-reduce operations 및 $where 연산자 표현식은 mongosh에서 사용할 수 있는 db와 같은 특정 글로벌 함수 또는 속성에 액세스 불가합니다.
다음 JavaScript 함수 및 속성은 및 map-reduce operations 및 $where연산자 표현식에 사용할 수 있습니다.
사용 가능한 속성 | 사용 가능한 기능 | |
|---|---|---|
argsMaxKeyMinKey | assert()BinData()DBPointer()DBRef()doassert()emit()gc()HexData()hex_md5()isNumber()isObject()ISODate()isString() | Map()MD5()NumberInt()NumberLong()ObjectId()print()printjson()printjsononeline()sleep()Timestamp()tojson()tojsononeline()tojsonObject()UUID()version() |
elemMatch
$where 쿼리 연산자를 최상위 문서에만 적용합니다. $where 쿼리 연산자는 중첩된 문서(예: $elemMatch 쿼리) 내부에서는 작동하지 않습니다.
고려 사항
전역 변수를 사용하지 마십시오.
$where는 JavaScript를 평가하며 인덱스를 활용할 수 없습니다. 따라서 표준 MongoDB 연산자(예:$gt,$in)를 사용하여 쿼리를 표현하면 쿼리 성능이 향상됩니다.일반적으로
$where는 다른 연산자를 사용하여 쿼리를 표현할 수 없는 경우에만 사용해야 합니다.$where를 사용해야 하는 경우 결과를 필터링하기 위해 하나 이상의 다른 표준 쿼리 연산자를 포함하세요.$where를 단독으로 사용하려면 컬렉션 스캔이 필요합니다.
일반 비-$where 쿼리 문을 사용하면 다음과 같은 성능상의 이점이 있습니다:
JavaScript 활성화
$where(또는 $function, $accumulator 또는 mapReduce)를 사용하려면 서버 사이드 스크립팅을 활성화해야 합니다(기본값).
그러나 이러한 작업을 사용하지 않는 경우 서버 쪽 스크립팅을 사용하지 않도록 설정합니다.
mongod인스턴스의 경우security.javascriptEnabled구성 옵션 또는 명령줄 옵션을 참조하세요--noscripting.mongos인스턴스의 경우security.javascriptEnabled구성 옵션 또는--noscripting명령줄 옵션을 참조하세요.
또한 ➤ 보안 구성 옵션으로 MongoDB 실행을 참조하세요.
지원되지 않는 배열 및 문자열 함수
MongoDB 6.0는 서버 측 JavaScript, $accumulator, $function 및 $where 표현식에 사용되는 내부 JavaScript 엔진을 MozJS-60에서 MozJS-91로 업그레이드합니다. MozJS-91에서는 MozJS-60에 존재했던 사용 중단된 비표준 배열과 문자열 함수가 제거되었습니다.
예시
players collection에 있는 다음 문서를 고려하세요.
db.players.insertMany([ { _id: 12378, name: "Steve", username: "steveisawesome", first_login: "2017-01-01" }, { _id: 2, name: "Anya", username: "anya", first_login: "2001-02-02" } ])
다음 예시에서는 $where와 hex_md5() JavaScript 함수를 사용하여 필드의 값을 name MD5 해시와 비교하고 일치하는 문서를 반환합니다.
db.players.find( { $where: function() { return (hex_md5(this.name) == "9b53e667f30cd329dca1ec9e6a83e994") } } );
이 연산은 다음과 같은 결과를 반환합니다.
{ "_id" : 2, "name" : "Anya", "username" : "anya", "first_login" : "2001-02-02" }
또는 $expr과 $function을 사용하여 이전 예시를 다시 작성할 수 있습니다. JavaScript에서 집계 연산자 $function을 사용해 사용자 지정 집계 표현식을 정의할 수 있습니다. db.collection.find()에서 $function과 다른 집계 연산자에 액세스하려면 $expr를 함께 사용하세요.
db.players.find( {$expr: { $function: { body: function(name) { return hex_md5(name) == "9b53e667f30cd329dca1ec9e6a83e994"; }, args: [ "$name" ], lang: "js" } } } )