За да търсите ключ във вложен документ, трябва да повторите полетата на документите рекурсивно, можете да направите това в JavaScript с помощта на $where метод в MongoDB. Заявката по-долу ще търси дали име на ключ съществува в документи и техните поддокументи.
Проверих това с примера, който сте дали, и той работи перфектно.
db.getCollection('test').find({ $where: function () {
var search_key = "lev3_field2";
function check_key(document) {
return Object.keys(document).some(function(key) {
if ( typeof(document[key]) == "object" ) {
if ( key == search_key ) {
return true;
} else {
return check_key(document[key]);
}
} else {
return ( key == search_key );
}
});
}
return check_key(this);
}}
);