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