MongoDB (поиск текста с соответствующим полем) проблема агрегации - PullRequest
0 голосов
/ 05 ноября 2018

У меня запрос агрегации MongoDB

db.data.aggregate([{ "$match" : { "$text" : { "$search" : "STORAGE TYPE" } } },

{ "$group" : 
                      { "_id" :{"doc_type": "$doc_type" ,"title" : "$title", "player_name" : "$player_name", "player_type" : "INSTITUTION", "country_code" :"$country_code" }, 
                       "number_records" : { "$sum" : 1}
  }
},
{"$match" : {"doc_type": "PATENT"} },
{"$sort":{"number_records" : -1}},
{"$limit" : 10}],

{"allowDiskuse" : true}

 )

Когда я пытался выполнить приведенный выше код, он продолжал буферироваться в течение длительного времени, я не получаю никакого вывода. Может кто-нибудь мне помочь? Когда я использовал команду объяснение (), он показывает следующий код:

{
    "stages" : [
        {
            "$cursor" : {
                "query" : {
                    "$and" : [
                        {
                            "$text" : {
                                "$search" : "STORAGE TYPE"
                            }
                        },
                        {
                            "doc_type" : "PATENT"
                        }
                    ]
                },
                "fields" : {
                    "country_code" : 1,
                    "doc_type" : 1,
                    "player_name" : 1,
                    "title" : 1,
                    "_id" : 0
                },
                "queryPlanner" : {
                    "plannerVersion" : 1,
                    "namespace" : "datadocuments.data",
                    "indexFilterSet" : false,
                    "parsedQuery" : {
                        "$and" : [
                            {
                                "doc_type" : {
                                    "$eq" : "PATENT"
                                }
                            },
                            {
                                "$text" : {
                                    "$search" : "STORAGE TYPE",
                                    "$language" : "english",
                                    "$caseSensitive" : false,
                                    "$diacriticSensitive" : false
                                }
                            }
                        ]
                    },
                    "winningPlan" : {
                        "stage" : "FETCH",
                        "filter" : {
                            "doc_type" : {
                                "$eq" : "PATENT"
                            }
                        },
                        "inputStage" : {
                            "stage" : "TEXT",
                            "indexPrefix" : {

                            },
                            "indexName" : "title",
                            "parsedTextQuery" : {
                                "terms" : [
                                    "storag",
                                    "type"
                                ],
                                "negatedTerms" : [ ],
                                "phrases" : [ ],
                                "negatedPhrases" : [ ]
                            },
                            "textIndexVersion" : 3,
                            "inputStage" : {
                                "stage" : "TEXT_MATCH",
                                "inputStage" : {
                                    "stage" : "FETCH",
                                    "inputStage" : {
                                        "stage" : "OR",
                                        "inputStages" : [
                                            {
                                                "stage" : "IXSCAN",
                                                "keyPattern" : {
                                                    "_fts" : "text",
                                                    "_ftsx" : 1
                                                },
                                                "indexName" : "title",
                                                "isMultiKey" : true,
                                                "isUnique" : false,
                                                "isSparse" : false,
                                                "isPartial" : false,
                                                "indexVersion" : 2,
                                                "direction" : "backward",
                                                "indexBounds" : {

                                                }
                                            },
                                            {
                                                "stage" : "IXSCAN",
                                                "keyPattern" : {
                                                    "_fts" : "text",
                                                    "_ftsx" : 1
                                                },
                                                "indexName" : "title",
                                                "isMultiKey" : true,
                                                "isUnique" : false,
                                                "isSparse" : false,
                                                "isPartial" : false,
                                                "indexVersion" : 2,
                                                "direction" : "backward",
                                                "indexBounds" : {

                                                }
                                            }
                                        ]
                                    }
                                }
                            }
                        }
                    },
                    "rejectedPlans" : [ ]
                }
            }
        },
        {
            "$group" : {
                "_id" : {
                    "doc_type" : "$doc_type",
                    "title" : "$title",
                    "player_name" : "$player_name",
                    "player_type" : {
                        "$const" : "INSTITUTION"
                    },
                    "country_code" : "$country_code"
                },
                "number_records" : {
                    "$sum" : {
                        "$const" : 1
                    }
                }
            }
        },
        {
            "$sort" : {
                "sortKey" : {
                    "number_records" : -1
                },
                "limit" : NumberLong("10")
            }
        }
    ],
    "ok" : 1
}

Я не мог понять ошибку; есть ли проблемы с агрегацией, если нет, то как увеличить производительность?

1 Ответ

0 голосов
/ 06 ноября 2018

Ваша ошибка возникла на втором этапе сопоставления: на данный момент doc_type не существует, но вместо него _id.doc_type. Но вам лучше объединить этот этап с первым, чтобы повысить производительность за счет сокращения количества документов, передаваемых на этап $ group.

Ваш улучшенный запрос будет:

db.data.aggregate([
  {"$match" : { "$text" : { "$search" : "STORAGE TYPE" `},"doc_type": "PATENT" } },`
  { "$group" : 
                      { "_id" :{"doc_type": "$doc_type" ,"title" : "$title", "player_name" : "$player_name", "player_type" : "INSTITUTION", "country_code" :"$country_code" }, 
                       "number_records" : { "$sum" : 1}
  }
},
  {"$sort":{"number_records" : -1}},
  {"$limit" : 10}],

{"allowDiskuse" : true}

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