Как преобразовать свойство в MongoDB из текста в тип даты? - PullRequest
49 голосов
/ 25 мая 2010

В MongoDB у меня есть документ с полем с именем "ClockInTime", который был импортирован из CSV в виде строки.

Как выглядит соответствующий оператор db.ClockTime.update() для преобразования этих текстовых значений в тип данных date?

Ответы [ 5 ]

81 голосов
/ 25 мая 2010

Этот код должен сделать это:

> var cursor = db.ClockTime.find()
> while (cursor.hasNext()) {
... var doc = cursor.next();
... db.ClockTime.update({_id : doc._id}, {$set : {ClockInTime : new Date(doc.ClockInTime)}})
... }
13 голосов
/ 04 июня 2013

У меня точно такая же ситуация, как у Джеффа Фрица.

В моем случае мне удалось найти следующее простое решение:

db.ClockTime.find().forEach(function(doc) { 
    doc.ClockInTime=new Date(doc.ClockInTime);
    db.ClockTime.save(doc); 
    })
5 голосов
/ 07 октября 2013

Это типовой пример кода на python с использованием pymongo

from pymongo import MongoClient
from datetime import datetime

def fixTime(host, port, database, collection, attr, date_format):
    #host is where the mongodb is hosted eg: "localhost"
    #port is the mongodb port eg: 27017
    #database is the name of database eg : "test"
    #collection is the name of collection eg : "test_collection"
    #attr is the column name which needs to be modified
    #date_format is the format of the string eg : "%Y-%m-%d %H:%M:%S.%f"
    #http://docs.python.org/2/library/datetime.html#strftime-and-strptime-behavior
    client = MongoClient(host, port)
    db = client[database]
    col = db[collection]
    for obj in col.find():
        if obj[attr]:
            if type(obj[attr]) is not datetime:
                time = datetime.strptime(obj[attr],date_format)
                col.update({'_id':obj['_id']},{'$set':{attr : time}})

для получения дополнительной информации: http://salilpa.com/home/content/how-convert-property-mongodb-text-date-type-using-pymongo

1 голос
/ 01 августа 2013

Если вам нужно проверить, было ли поле уже преобразовано, вы можете использовать это условие:

/usr/bin/mongo mydb --eval 'db.mycollection.find().forEach(function(doc){
    if (doc.date instanceof Date !== true) {
        doc.date = new ISODate(doc.date);
        db.mycollection.save(doc);
    }
});'

В противном случае командная строка может прерваться.

0 голосов
/ 13 июня 2019

Начиная с Mongo 4.x:

  • db.collection.update() может принять конвейер агрегации, что в итоге позволяет обновить поле на основе его текущего значения (Mongo 4.2+).
  • Появился новый $toDate оператор агрегирования (Mongo 4.0).

такой, что:

// { a: "2018-03-03" }
db.collection.update(
  {},
  [{ $set: { a: { $toDate: "$a" } } }],
  { multi: true }
)
// { a: ISODate("2018-03-03T00:00:00Z") }
  • Первая часть {} - это запрос на совпадение, отфильтровывающий, какие документы обновлять (в данном случае все документы).

  • Вторая часть [{ $set: { a: { $toDate: "$a" } } }] - это конвейер агрегации обновлений (обратите внимание на квадратные скобки, обозначающие использование конвейера агрегации). $set - это новый оператор агрегирования, который в этом случае заменяет значение поля. Замененное значение, являющееся самим полем, согласованным с ISODate объектом. Обратите внимание, как a изменяется непосредственно на основе его собственного значения ($a).

  • Не забудьте { multi: true }, иначе будет обновлен только первый соответствующий документ.

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