คุณสามารถใช้ตัวดำเนินการ $in สำหรับสิ่งนี้ ให้เราสร้างคอลเลกชันที่มีเอกสารก่อน -
> db.searchForStringOrNumberDemo.insertOne(
{
"_id": new ObjectId(),
"StudentName": "Larry",
"StudentDetails": {
"StudentMarks": {
"StudentMongoDBMarks": [44]
}
}
}
);
{
"acknowledged" : true,
"insertedId" : ObjectId("5ce2407c36e8b255a5eee944")
}
> db.searchForStringOrNumberDemo.insertOne( { "_id": new ObjectId(), "StudentName": "Larry", "StudentDetails": { "StudentMarks": { "StudentMongoDBMarks": ["44"] } } } );
{
"acknowledged" : true,
"insertedId" : ObjectId("5ce240f036e8b255a5eee945")
} ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงเอกสารทั้งหมดจากคอลเลกชันโดยใช้วิธี find() -
> db.searchForStringOrNumberDemo.find().pretty();
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{
"_id" : ObjectId("5ce2407c36e8b255a5eee944"),
"StudentName" : "Larry",
"StudentDetails" : {
"StudentMarks" : {
"StudentMongoDBMarks" : [
44
]
}
}
}
{
"_id" : ObjectId("5ce240f036e8b255a5eee945"),
"StudentName" : "Larry",
"StudentDetails" : {
"StudentMarks" : {
"StudentMongoDBMarks" : [
"44"
]
}
}
} ต่อไปนี้เป็นแบบสอบถามเพื่อค้นหาสตริงหรือตัวเลขในฟิลด์ -
>db.searchForStringOrNumberDemo.find({"StudentDetails.StudentMarks.StudentMongoDBMarks": { "$in": ["44",44] } }); สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
{ "_id" : ObjectId("5ce2407c36e8b255a5eee944"), "StudentName" : "Larry", "StudentDetails" : { "StudentMarks" : { "StudentMongoDBMarks" : [ 44 ] } } }
{ "_id" : ObjectId("5ce240f036e8b255a5eee945"), "StudentName" : "Larry", "StudentDetails" : { "StudentMarks" : { "StudentMongoDBMarks" : [ "44" ] } } }