쿼리를 동적으로 작성하려면 몇 가지 스크립트를 작성해야 합니다. 먼저 문서로 컬렉션을 생성해 보겠습니다. −
> db.dynamicQueryDemo.insertOne({"Name":"John","Subject":["MongoDB","MySQL"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cef5c5def71edecf6a1f69a")
}
> db.dynamicQueryDemo.insertOne({"Name":"John","Subject":["C","C++"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cef5c73ef71edecf6a1f69b")
}
> db.dynamicQueryDemo.insertOne({"Name":"John","Subject":["MongoDB","Java"]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cef5c8bef71edecf6a1f69c")
} find() 메서드를 사용하여 컬렉션의 모든 문서 표시 -
> db.dynamicQueryDemo.find().pretty();
이것은 다음과 같은 출력을 생성합니다 -
{
"_id" : ObjectId("5cef5c5def71edecf6a1f69a"),
"Name" : "John",
"Subject" : [
"MongoDB",
"MySQL"
]
}
{
"_id" : ObjectId("5cef5c73ef71edecf6a1f69b"),
"Name" : "John",
"Subject" : [
"C",
"C++"
]
}
{
"_id" : ObjectId("5cef5c8bef71edecf6a1f69c"),
"Name" : "John",
"Subject" : [
"MongoDB",
"Java"
]
} 다음은 MongoDB 쿼리를 동적으로 빌드하는 쿼리입니다 -
> function findDocument(subject) {
var find = {};
if (subject.length == 0)
find["$nin"] = subject;
else
find["$in"] = subject;
return find;
}
> var sub = ["MySQL","MongoDB"];
> var myDoc = findDocument(sub);
> db.dynamicQueryDemo.aggregate([{
$match: {
"Subject": myDoc,
}
}]); 이것은 다음과 같은 출력을 생성합니다 -
{ "_id" : ObjectId("5cef5c5def71edecf6a1f69a"), "Name" : "John", "Subject" : [ "MongoDB", "MySQL" ] }
{ "_id" : ObjectId("5cef5c8bef71edecf6a1f69c"), "Name" : "John", "Subject" : [ "MongoDB", "Java" ] }