Mongo DB 创建一个以日期为键的数组


Mongo DB make an array with date as key?

Mongo用日期做一个数组作为键?

[_id] => MongoId Object (
    [$id] => 4fcf2f2313cfcd225700000d
)
[id] => 14
[name] => Aryan Roban
[news] => Array (
    [08-06-2012] => 12
)

在这里,我想要一个以日期为键的数组,以及如何删除特定的键行?

例如

我想删除新闻数组中键为"08-06-2012"的数组元素,我不知道它的值。

查找文档不会有问题,这很容易。只需查看news是否有与您的搜索条件匹配的密钥:

db.foo.find({'news.08-06-2012': {'$exists': true}})

不要忘记在news上放置索引。

但是删除它们并不容易。还有另一个线程显示了一种方法,但它实际上是一种解决方法: 在mongoDb中,如何通过索引删除数组元素 可悲的是,这仅适用于具有数字索引的数组,而不适用于关联数组。

也许您可以使用自己的新闻收藏?然后,您可以轻松更新和删除它们。否则,您可以从数据库中加载完整的文档,在应用程序中操作新闻,然后保存。这将需要两个日期库查询,但应该可以工作。

我们可以像

db.foo.update({/*...*/}, {$unset: {'news.11-06-2012', 1}})