Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/236.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
查询以提取mongodb和php数组中的文档_Php_Arrays_Mongodb - Fatal编程技术网

查询以提取mongodb和php数组中的文档

查询以提取mongodb和php数组中的文档,php,arrays,mongodb,Php,Arrays,Mongodb,我有一个来自MongoDB的这种形式的JSON,我想基于相同的查询检索文档: { "_id" : ObjectId("5281fb3070c68c0c1ccc4f00"), "channel" : "1", "content" : "8578", "duplicateOf" : null, "id" : "7420", "keywords" : [ObjectId("52816d3370c68c2c1c450500"),

我有一个来自MongoDB的这种形式的JSON,我想基于相同的查询检索文档:

 {
      "_id" : ObjectId("5281fb3070c68c0c1ccc4f00"),
      "channel" : "1",
      "content" : "8578",
      "duplicateOf" : null,
      "id" : "7420",
      "keywords" : [ObjectId("52816d3370c68c2c1c450500"), ObjectId("52816d3370c68c2c1c570500"), ObjectId("52816d3370c68c2c1c470500"), ObjectId("52816d3370c68c2c1c4d0500"), ObjectId("52816d3370c68c2c1c590500"), ObjectId("52816d3370c68c2c1c530500"), ObjectId("52816d3370c68c2c1c4f0500"), ObjectId("52816d3370c68c2c1c6b0500")],
      "lastUpdate" : "2009-11-16"]
    }
我将此查询用于MongoVue,它可以工作:

   db.Measurements.find({ "_id" : 
{ "$in" : [ObjectId("5281fb3070c68c0c1ccc4f00"), ObjectId("5281fb3070c68c0c1cce4f00")] } })
但是我没有找到在PHP中工作的方法,下面是代码的一部分:

 foreach ($series as $doc) {

       $ids = $collectionMeasurements->find(array('_id' => array($in=>new MongoId($doc[keywords]))));
    }
谢谢你的帮助

===================================================== 发现错误

 foreach ($series as $doc) {

 $ids = $collectionMeasurements->find(array('_id' => array(
           '$in'=>array(new MongoId(string)($doc[keywords])))));
    }

$in
在PHP中是一个变量。它必须是一个字符串(反正在MongoVue代码中也是这样)

这可能还需要一个数组作为
$in
的参数,就像
数组(新MongoId
一样,或者您可以传入
$series

您正在使用的

array( $in => new MongoId($doc[keywords]) )
你应使用:

array( '$in' => new MongoId($doc[keywords]) )

使用“单引号”,否则使用“双引号”,PHP将尝试将$in解释为PHP变量。

谢谢,但这不起作用!!!$ids=$collectionMeasurements->find(数组(“'id'=>array('in'=>array('doc[measurements]));您的$doc[“keywords”](可能还有$doc[“measurements”]是MongoID的数组。但MongoID的构造函数不接受值数组。如果这些元素尚未成为MongoID的实例,则需要为它们中的每个元素构造一个新的MongoID
array( '$in' => new MongoId($doc[keywords]) )