元のクエリでは、timestamp
は単なる文字列フィールドでありDate()
、Mongoシェルでは文字列として扱われます。これらのオペランドの比較は、他の文字列比較と同じように機能します。
$ mongo
MongoDB shell version: 2.2.0-rc1-pre-
connecting to: test
> db.foo.drop()
true
> db.foo.insert({ x: Date() });
> db.foo.find()
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> sleep(1000)
null
> db.foo.find({ x: { $lt: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.find({ x: { $gt: Date() }});
>
ISODate()
はMongoの日付フィールド$gt
に相当するJSであり、 or$lt
演算子を使用する場合の文字列値とは比較できません。
> db.foo.find({ x: { $gt: ISODate() }});
> db.foo.find({ x: { $lt: ISODate() }});
> db.foo.find({ x: { $ne: ISODate() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.insert({x: ISODate() });
> db.foo.find({ x: {$gt: Date() }});
> db.foo.find({ x: {$lt: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
> db.foo.find({ x: {$ne: Date() }});
{ "_id" : ObjectId("50218e808930273947a21cf3"), "x" : "Tue Aug 07 2012 17:54:09 GMT-0400 (EDT)" }
{ "_id" : ObjectId("50218fa18930273947a21cf4"), "x" : ISODate("2012-08-07T21:58:57.350Z") }
>
Mongoは、文字列が日付の前に来るタイプ間の比較順序を定義しますが、同じフィールドがコレクション全体で異なるタイプを持つ可能性がある場合の並べ替え順序に関連しています。
自分が頻繁に行うことを想定している場合(バッチプロセスなど)に古いレコードを削除する場合は、次の2.2リリースの新機能であるTTLコレクションに関心がある可能性があることに注意してください。Kristina Chodorowも、このブログエントリでこのトピックに関する面白い紹介を書きました。