当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《如何在PHP中进行MongoDB控制台式查询?》经验,为你挑选了1个好方法。

我正在尝试从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,但我很快就开始讨厌将每个查询转换为本地作者想要的格式...



1> Gates VP..:

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

你的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);

所以我基本上换了

带有"箭头"的"点"

带有"双箭头"的"冒号"

"左大括号"与"阵列"("

"右支撑"与")"

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


最好不要在查询中使用双引号."$ exists","$ not","$ nin"等因为php尝试首先尝试将其作为变量进行评估.用单引号写出来更好.
推荐阅读
U友50081205_653
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有