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}})