Вложенный поиск Pymongo

У меня есть вложенные данные в mongo, которые я пытаюсь (безуспешно) запросить. Пример документа, который я пытаюсь найти, показан ниже:

{
    'T009_Measurments': {
        'ConditionKey': 'WPS-ActivePower 0-920,',
        'HalfLifeDays': 100,
        'ID': 120,
        'LocationName': 'T001',
        'MeasurementKey': 'Some DATA/LOC/LOC LOC/FFT_16000',
        'Overload': 0,
        'RPM': 1496.6044,
        'RedAlarm': 0,
        'TimeClosed-Min': 1440,
        'Trigger_Time': datetime.datetime(2099, 6, 11, 20, 20, 40),
        'WPS-ActivePower-Average': 727.0,
        'WPS-ActivePower-Deviation': 0.0,
        'YellowAlarm': 0
    }
}

Что я действительно хочу делать, так это искать по HalfLifeDays. Я пробовал несколько вещей, в том числе:

db.collection.find({'T009_Measurments.HalfLifeDays' : 100})
db.collection.find({'T009_Measurments'}: {'HalfLifeDays' : 100})

Но пока ничего не могу получить. Что я делаю неправильно?

Мне кажется, что первый нашел, есть ли сообщение об ошибке?

Bubble Bubble Bubble Gut 18.04.2018 04:49

Код выполняется без сообщения об ошибке, однако данные не возвращаются. Когда я подсчитываю, я получаю 0.

thomaskh522 18.04.2018 04:54

Получаете ли вы правильное количество документов при использовании db.collection.count()?

Bubble Bubble Bubble Gut 18.04.2018 04:57

Да. Там вроде все хорошо.

thomaskh522 18.04.2018 05:08

Правильно ли вы ввели название своей коллекции? В данном примере это просто collection

l0n3sh4rk 18.04.2018 09:13

У меня действительно указано правильное имя коллекции ... Я собираюсь более внимательно изучить структуру документа ... Думаю, я что-то упускаю.

thomaskh522 18.04.2018 22:06

Теперь я успешно выполнил запрос с помощью метода поиска и поиска по идентификатору. Так что я не думаю, что моя структура испорчена.

thomaskh522 19.04.2018 03:18
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
7
119
1

Ответы 1

Как и многие другие проблемы, это может быть связано с ошибкой пользователя. В моем запросе были неправильные ссылки. Я обнаружил это только тогда, когда в чистом отчаянии скопировал ключ из: Object.keys(db.collectionName.findOne())

и вставил в свой запрос. Дальше все нормально заработало. Спасибо всем, кто дал советы по устранению неполадок.

Другие вопросы по теме