如何在PHP中进行MongoDB控制台式查询?

时间:2011-11-28 17:46:58

标签: php mongodb

我正在尝试从javascript控制台获取MongoDB查询到我的PHP应用程序中。我试图避免的是必须将查询转换为PHP“本机驱动程序”的格式...我不想手工构建数组和手工链函数,而不是手动构建数组MySQL的内部查询结构只是为了获取数据。

我已经有一个字符串在Mongo控制台中生成我想要的确切内容:

db.intake.find({"processed": {"$exists": "false"}}).sort({"insert_date": "1"}).limit(10);

问题是,有没有办法让我把这个字符串交给MongoDB并让它返回一个带有我请求的数据集的游标?

现在我正在“编写你自己的解析器,因为它无效json有点将有效的Mongo查询的子集转换为PHP本机驱动程序想要的格式”状态,这不是很有趣。

我不想要ORM或大型包装库;我只是想给一个函数我的查询字符串,因为它存在于控制台中,并得到一个我可以使用的迭代器。我知道有几个基于PHP的Mongo管理器应用程序显然采用控制台式查询并处理它们,但是初步浏览它们的代码,我不确定它们如何处理翻译。

我非常喜欢在控制台中使用mongo,但我很快就开始讨厌将每个查询转换为本地作者想要的格式......

3 个答案:

答案 0 :(得分:14)

  

我不想手工构建数组和手工链函数......

您的shell代码中填充了“hand build dictionaries”“hand-chain functions”。所有这些点都是链式函数,所有JSON都代表字典/哈希表。

让我们快速比较一下。

<强>使用Javascript:

db.intake
  .find({"processed": {"$exists": false}})
  .sort({"insert_date": "1"})
  .limit(10);

<强> PHP:

db->intake
  ->find(array('processed'=> array('$exists'=> false)))
  ->sort(array('insert_date'=> '1'))
  ->limit(10);

所以我基本上取代了

  • “dots”with“arrows”
  • “冒号”与“双箭头”
  • “left brace”with“array(”
  • “右支撑”与“)”

听起来你真的对PHP很生气。我可以理解PHP可以是一种迟钝的语言。但是,当谈到MongoDB PHP驱动程序时,语法与“原始”javascript一样尽可能接近。

答案 1 :(得分:2)

您可以使用json_decode()仍然有效地执行查询(使用MongoDB::execute效率不高)并获取光标。如,

$db->intake->find(json_decode('{"processed": {"$exists": "false"}}'))
    ->sort(json_decode('{"insert_date": "1"}'))->limit(10);

不确定这是否比使用关联数组更好,但它是一个选项。这样你只需要查看“JSON”查询语法。

(另外,我认为您的意思是$exists:false,而不是$exists:"false"。)

答案 2 :(得分:0)

MongoDB::execute应该允许您运行任何JavaScript代码,但遗憾的是会返回字符串,因此您只需要使用JavaScript实际迭代数据集。

>> $d = new Mongo
Mongo::__set_state(array(
   'connected' => true,
   'status' => NULL,
   'server' => '',
   'persistent' => NULL,
))
>> $db = $d->database;
MongoDB::__set_state(array(
   'w' => 1,
   'wtimeout' => 10000,
))
>> $db->execute('db.intake.find({"processed": {"$exists": "false"}}).sort({"insert_date": "1"}).limit(10);');
array (
  'retval' =>
  array (
    'value' => 'DBQuery: database.intake -> undefined',
  ),
  'ok' => 1,
)