2

您能否告诉我是否可以在 mongodb 中使用数字字段名称,例如:{“1”:“value1”、“2”:“value2”、“3”:55}。看起来我可以使用 mongodb 命令行输入此类数据,但是当我尝试使用 php 编写此类数据时遇到问题,得到消息:字段名称必须是字符串错误。

我在这里http://www.mongodb.org/display/DOCS/Collections找到了关于 mongodb 中集合命名的信息,但是我没有找到关于字段名称命名的信息。谢谢你。

我在 php 中为数组尝试了这个:

$elements[1] = 1;
$index = "2";
settype($index, "string");
$elements[$index] = 2;
$elements["3"] = 3;
var_dump($elements);

它显示:

array
  1 => int 1
  2 => int 2
  3 => int 3

我谈论的错误是:

发生错误应用程序错误异常信息:

消息:字段名称必须是字符串堆栈跟踪:

#0 C:\library\Shanty\Mongo\Collection.php(376): MongoCollection->find(Array, Array)
#1 C:\git_reps\mailable\application\models\Subscriber1.php(191): Shanty_Mongo_Collection::all(Array, Array)
#2 C:\git_reps\mailable\application\models\Subscriber1.php(203): Model_Subscriber1::getCursor(Array, Array, Array)
#3 C:\git_reps\mailable\application\controllers\ListsController.php(639): Model_Subscriber1::getPaginator(Array, Array, Array)
#4 C:\library\Zend\Controller\Action.php(513): ListsController->view1Action()
#5 C:\library\Zend\Controller\Dispatcher\Standard.php(295): Zend_Controller_Action->dispatch('view1Action')
#6 C:\library\Zend\Controller\Front.php(954): Zend_Controller_Dispatcher_Standard->dispatch(Object(Zend_Controller_Request_Http), Object(Zend_Controller_Response_Http))
#7 C:\library\Zend\Application\Bootstrap\Bootstrap.php(97): Zend_Controller_Front->dispatch()
#8 C:\library\Zend\Application.php(366): Zend_Application_Bootstrap_Bootstrap->run()
#9 C:\git_reps\mailable\public\index.php(25): Zend_Application->run()
#10 {main}  

Request Parameters:

array (
  'controller' => 'lists',
  'action' => 'view1',
  'module' => 'default',
  'id' => '52',
)  

当我尝试获取诸如“1”之类的 mongodb cursuro 设置字段时会发生这种情况。

4

3 回答 3

4

我的猜测是,当您将数字用作字符串时,PHP 正在执行某种自动转换。尝试使用 settype ( http://php.net/manual/en/function.settype.php ) 以确保它被设置为字符串而不是转换为整数,看看这是否允许您具有与MongoDB 外壳。

于 2012-02-28T15:01:12.513 回答
3

当您将 json 文档存储在 mongodb 中时,您应该参考http://www.json.org/以了解命名规范。那里的对象定义说键必须是字符串。

因此,您必须将数字包装为字符串,然后才能将其用作属性名称。

于 2012-02-28T13:38:19.790 回答
3

PHP 驱动程序有点过分热衷于保护您不返回数字字段。幸运的是,你可以破解它。

所以,这不起作用,因为 MongoCursor 构造函数会检查它:

$cursor = $collection->find($criteria, array("2" => 1));

但这确实如此,因为该fields方法没有与构造函数相同的检查:

$cursor = $collection->find($criteria)->fields(array("2" => 1));

我为此提交了一个错误:https ://jira.mongodb.org/browse/PHP-338

(顺便说一句,将来它可以帮助我们在提供更大的代码示例时进行调试。)

于 2012-02-28T21:16:07.383 回答