duanjiang7505 2012-07-03 18:00
浏览 73
已采纳

PHP MongoDB查找数组ne值中的第一项

I have a collection with a document like this:

{
 "name" : "some",
 "items" : [
      {"_id" : 0,
       "name" : "item name"},
      {"_id" : 2,
       "name" : "item name"},
      {"_id" : 0,
       "name" : "item name"}
  ]
}

I want to select all documents where the the first index in items has an _id equal to 0.

Any ideas how to do this?

Thank you!

Edit:

I've tried this:

$items->find(array('items' => array('_id' => array('$ne' => 0))));

and

$items->find(array('items[0]' => array('_id' => array('$ne' => 0))));

Both return empty however.

  • 写回答

1条回答 默认 最新

  • douliudong8108 2012-07-03 19:27
    关注

    try this:

    db.items.find({'items.0._id': {$ne: 0}})
    

    This will select all documents where first element in the subarray has _id not equal to 0. If you want to find equals, use this simpler form:

    db.items.find({'items.0._id': 0})
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 ensp的问题(需要各个路由器命令)
  • ¥15 Matlab怎么求解含参的二重积分?
  • ¥15 苹果手机突然连不上wifi了?
  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题