запрос монго - получение конкретного объекта (его `_id` известен) из массива объекта, НО этот массив также является частью списка документов - PullRequest
0 голосов
/ 05 сентября 2018

как я могу запросить конкретное сообщение из входящих или исходящих сообщений, если у меня есть _id -> то есть идентификатор сообщения.

this is my route 
get("/getSpecificMessage/{Message_id}", (req, res) => {..}

что я могу сделать, это найти всех покупателей / дилеров, а затем пройти через входящие / исходящие сообщения всех покупателей / дилеров, а затем найти сообщение с _id, т.е. message_id -> Могу ли я сделать это лучше, чем это.

{
        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e1"),
        "address" : {
                "proper_address" : "sarai kale khan",
                "lat" : 28.58894,
                "long" : "77.25692"
        },
        "name" : "prashant",
        "password" : "jfalksdjlk;jasdl",
        "email" : "prashant@gmail.com",
        "inbox" : [
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e4"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "from" : "1@1.com",
                        "message" : "message_1"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e3"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "from" : "2@2.com",
                        "message" : "message_2"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e2"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "from" : "3@3.com",
                        "message" : "message_3"
                }
        ],
        "outbox" : [
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e7"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "to" : "1@1.com",
                        "message" : "message_4"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e6"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "to" : "1@1.com",
                        "message" : "message_5"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e5"),
                        "date" : ISODate("2018-09-04T23:03:41.627Z"),
                        "to" : "1@1.com",
                        "message" : "message_6"
                }
        ],
        "__v" : 0
}
{
        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e8"),
        "address" : {
                "proper_address" : "najafgarah",
                "lat" : 28.58894,
                "long" : "77.25692"
        },
        "name" : "rahul",
        "password" : "jkalsjdflasdl",
        "email" : "rahul@gmail.com",
        "inbox" : [
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083eb"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "from" : "1@1.com",
                        "message" : "message_1"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083ea"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "from" : "2@2.com",
                        "message" : "message_2"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083e9"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "from" : "3@3.com",
                        "message" : "message_3"
                }
        ],
        "outbox" : [
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083ee"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "to" : "1@1.com",
                        "message" : "message_4"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083ed"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "to" : "1@1.com",
                        "message" : "message_5"
                },
                {
                        "_id" : ObjectId("5b8f0f4de276dd1e0ff083ec"),
                        "date" : ISODate("2018-09-04T23:03:41.639Z"),
                        "to" : "1@1.com",
                        "message" : "message_6"
                }
        ],
        "__v" : 0
}

Так что, если у меня есть _id = 5b8f0f4de276dd1e0ff083ea, и я хочу

{
  "_id" : ObjectId("5b8f0f4de276dd1e0ff083ea"),
  "date" : ISODate("2018-09-04T23:03:41.639Z"),
  "from" : "2@2.com",
  "message" : "message_2"
}

Ответы [ 2 ]

0 голосов
/ 05 сентября 2018

Это то, что вы можете сделать, используя структуру агрегирования:

var oId = new ObjectId("5b8f0f4de276dd1e0ff083ea");

db.collection.aggregate({
    $match: { // can be skipped but I'd personally keep it because this will use an index on "input._id"/"output._id" (if there is one) to filter out irrelevant documents
        $or: [
            { "inbox": { $elemMatch: { "_id": oId } } },
            { "outbox": { $elemMatch: { "_id": oId } } },
        ]
    }
}, {
    $project: {
        result: {
            $concatArrays: [
                { $filter: { "input": "$inbox", "cond": { $eq: [ "$$this._id", oId ] } } },
                { $filter: { "input": "$outbox", "cond": { $eq: [ "$$this._id", oId ] } } }
            ]
        }
    }
}, {
    $unwind: "$result" // flatten the result array
}, {
    $replaceRoot: {
        "newRoot": "$result" // move "result" contents all the way up
    }
})
0 голосов
/ 05 сентября 2018

Я не уверен, хотите ли вы использовать скрипты MongoDB или язык вашего приложения (если я ошибаюсь)

Вот как это работает в Mongo Shell Script

db.MODEL.find( { _id: DOCUMENT_ID },
                     { inbox: { $elemMatch: { _id: MESSAGE_ID } } } )

Документация здесь

Если это не то, что вы хотите, пожалуйста, обновите ваш пост и добавьте, какой язык / рамки вы используете

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...