Es gibt viele Artikel und SO-Fragen zum MongoDB-Datenmodell zum Speichern alter Revisionen von Dokumenten.MongoDB-Design für revisionierte Daten
Jedoch fand ich nichts, das eine meiner Anforderungen erfüllte; Ich muss in der Lage sein, die Datenbank rückwirkend abzufragen, um alle Dokumente eindeutig zu finden, die zu einem bestimmten Zeitpunkt ein willkürliches Kriterium erfüllten.
Um zu klären, muss ich in der Lage sein, die Frage effizient zu beantworten;
"Welche Dokumente (und vorzugsweise Versionen) stimmten den Kriterien {X: Y ...} zur Zeit T" zu.
Pseudocode:
/* Would match a version that were active from 2010 - 2016-05-01 with zipcode 12345 */
db.my_objs.find({zipcode: "12345", ~time: ISODate("2016-01-01 22:14:31.003")~})
Ich habe es nicht geschafft eine Lösung zu finden, die weder auf Google noch ich. Ich habe versucht;
- Mit einem einfachen „aus“ auf Daten -timestamp, und wählen Sie dann „das erste Element vor meinem abgefragt Zeitpunkt, die auch andere Kriterien entspricht“, aber ich habe es nicht geschafft, dass in Mongo auszudrücken.
- Mit einem von/zu jeder Version, und immer wenn ich eine neue Version schreibe, update "to" auf der vorherigen Version zu entsprechen von der neuen Version. Ich habe jedoch keinen Weg gefunden, dies atomar oder mit einer eventuellen Konsistenz zu tun, was bedeutet, dass mehrere Aktualisierungen Verwüstungen anrichten und mehrdeutige Zeitlinien erzeugen könnten. (Doppeleinträge für den gleichen Zeitpunkt)
Irgendwelche Ideen?
bearbeiten eine unerwünschte Beispiel Abfrage für # 1
db.my_objs.find({
data : {
$elemMatch : {
from : {
$lte : ISODate('2015-01-01')
}
}
}
}, {
"data.$" : 1
}).forEach(function (obj) {
if(obj.data[0].state == 'active') {
printjson(registrar)
}
})–
könnten Sie zeigen Sie Ihre Anfrage nach 'Nummer 1'? – profesor79
Wie ich schrieb, war ich nicht in der Lage, eine solche Abfrage auszudrücken? – Rawler
ok, habe das - dachte, dass du eine Skizze davon hast – profesor79