1

我正在使用 PHP 和 MongoDB 来解决问题并获得离我的位置最近的点。但我有一个问题。

当我使用 mongo 控制台时,它会返回值,但是当我使用 PHP 代码时,它会返回一个空对象。

PHP代码:

$connection = new MongoClient( "mongodb://localhost" );
$db = $connection->collection;
$collection = $db->user_location;

// There are many differnt queries (by token, by email...)
if (isset($_GET['email'])) {
    $query = array(
    //'email' => array( '$neq' => $_GET['email']),
    'loc' => array(
        '$near' => array(
        'lon' => floatval($_GET['longitude']),
        'lat' => floatval($_GET['latitude']), 
        '$maxDistance' => intval($_GET['distance']))));
}

$maxDistance = $_GET["distance"];
$lon = $_GET['longitude'];
$lat = $_GET['latitude'];

$cursor = $collection->find($query);
if ($cursor) {
    echo json_encode($cursor);
} else {
    echo "{ 'status' : 'false' }";
}

这是 mongo 控制台使用的示例: db.user_location.ensureIndex({ loc : "2d"} )

db.user_location.find() {“_id”:ObjectId(“51dbe817617c6df061000000”),“email”:“zgz”,“loc”:{“lon”:-0.88588498,“lat”:41.68035677},“date”: "2013 年 7 月 9 日星期二 06:38:15" } db.user_location.find({"loc": {"$near": {"lon":-0.88588498,"lat":41.68035677}, "$maxDistance": 99}}){“_id”:ObjectId(“51dbe817617c6df061000000”),“电子邮件”:“zgz”,“loc”:{“lon”:-0.88588498,“lat”:41.68035677},“日期”:“星期二, 2013 年 7 月 9 日 06:38:15"}

如果我在我的 PHP 代码中使用相同的值,它会返回一个空游标。为什么?谢谢!

4

2 回答 2

1

根据这个MongoDB $near doc查询应该是这样的:

$query = array(    
    'loc' => array(
        '$near' => array(
            floatval($_GET['longitude']),
            floatval($_GET['latitude']), 
        )
        '$maxDistance' => intval($_GET['distance'])),
    ),
);

在调用之前,您应该使用isset函数检查 $_GET['longtitude'] 等。

于 2013-07-09T11:24:50.633 回答
1

我有解决办法。

我遇到的问题是我试图直接返回 $cursor 但是 $collection->find($query) 返回超过 1 个对象(注意 $findOne() 只返回 1,所以你不会有问题返回$光标)。在这种情况下(使用 find()),您需要返回 iterator_to_array($cursor)。

$cursor = $collection->find($query);
if ($cursor) {
    echo json_encode(iterator_to_array($cursor));
} else {
    echo "{ 'status' : 'false' }";
}
于 2013-08-19T13:54:29.923 回答