我正在使用 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 代码中使用相同的值,它会返回一个空游标。为什么?谢谢!