คำถามติดแท็ก projection

14
ดึงเฉพาะองค์ประกอบที่สอบถามในอาร์เรย์วัตถุในคอลเลกชัน MongoDB
สมมติว่าคุณมีเอกสารต่อไปนี้ในคอลเล็กชันของฉัน: { "_id":ObjectId("562e7c594c12942f08fe4192"), "shapes":[ { "shape":"square", "color":"blue" }, { "shape":"circle", "color":"red" } ] }, { "_id":ObjectId("562e7c594c12942f08fe4193"), "shapes":[ { "shape":"square", "color":"black" }, { "shape":"circle", "color":"green" } ] } ทำแบบสอบถาม: db.test.find({"shapes.color": "red"}, {"shapes.color": 1}) หรือ db.test.find({shapes: {"$elemMatch": {color: "red"}}}, {"shapes.color": 1}) ส่งคืนเอกสารที่จับคู่(เอกสาร 1)แต่จะเสมอกับรายการอาร์เรย์ทั้งหมดในshapes: { "shapes": [ {"shape": "square", "color": "blue"}, {"shape": "circle", …

19
วิธีการเลือกเขตข้อมูลเดียวสำหรับเอกสารทั้งหมดในคอลเลกชัน MongoDB?
ใน MongoDB ของฉันฉันมีคอลเลกชันของนักเรียนที่มี 10 บันทึกที่มีสาขาและname rollหนึ่งบันทึกของคอลเลกชันนี้คือ: { "_id" : ObjectId("53d9feff55d6b4dd1171dd9e"), "name" : "Swati", "roll" : "80", } ฉันต้องการดึงข้อมูลฟิลด์rollสำหรับบันทึกทั้ง 10 รายการในคอลเล็กชันเท่าที่เราจะทำได้ในฐานข้อมูลดั้งเดิมโดยใช้: SELECT roll FROM student ฉันไปผ่านบล็อกจำนวนมาก แต่ทั้งหมดเกิดจากการสืบค้นซึ่งจะต้องมีWHEREข้อในตัวอย่างเช่น: db.students.find({ "roll": { $gt: 70 }) แบบสอบถามเทียบเท่ากับ: SELECT * FROM student WHERE roll > 70 ความต้องการของฉันคือการหาคีย์เดียวเท่านั้นโดยไม่มีเงื่อนไขใด ๆ ดังนั้นการดำเนินการแบบสอบถามสำหรับสิ่งที่
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.