Пример локатора магазина - не удается получить записи для возврата - PullRequest
0 голосов
/ 10 ноября 2011

Интересно, сможет ли кто-нибудь мне помочь, пожалуйста. Я пытаюсь научиться создавать «Локатор магазина» и прорабатываю пример, показанный на сайте разработчиков Google.

Я добавил записи в свою базу данных и создал форму HTML, но не могу заставить скрипт php работать, т.е. записи не возвращаются.

<?php  
require("phpfile.php");

// Get parameters from URL
$center_lat = $_GET["lat"];
$center_lng = $_GET["lng"];
$radius = $_GET["radius"];

// Start XML file, create parent node
$dom = new DOMDocument("1.0");
$node = $dom->createElement("markers");
$parnode = $dom->appendChild($node);

// Opens a connection to a mySQL server
$connection=mysql_connect ("hostname", $username, $password);
if (!$connection) {
  die("Not connected : " . mysql_error());
}

// Set the active mySQL database
$db_selected = mysql_select_db($database, $connection);
if (!$db_selected) {
  die ("Can\'t use db : " . mysql_error());
}

// Search the rows in the markers table
$query = sprintf("SELECT address, name, lat, lng, ( 3959 * acos( cos( radians('%s') ) * cos( radians( lat ) ) * cos( radians( lng ) - radians('%s') ) + sin( radians('%s') ) * sin( radians( lat ) ) ) ) AS distance FROM markers HAVING distance < '%s' ORDER BY distance LIMIT 0 , 20",
  mysql_real_escape_string($center_lat),
  mysql_real_escape_string($center_lng),
  mysql_real_escape_string($center_lat),
  mysql_real_escape_string($radius));
$result = mysql_query($query);

if (!$result) {
  die("Invalid query: " . mysql_error());
}

header("Content-type: text/xml");

// Iterate through the rows, adding XML nodes for each
while ($row = @mysql_fetch_assoc($result)){
  $node = $dom->createElement("marker");
  $newnode = $parnode->appendChild($node);
  $newnode->setAttribute("name", $row['name']);
  $newnode->setAttribute("address", $row['address']);
  $newnode->setAttribute("lat", $row['lat']);
  $newnode->setAttribute("lng", $row['lng']);
  $newnode->setAttribute("distance", $row['distance']);
}

echo $dom->saveXML();
?>

Я уже давно смотрю на это и не могу понять, где я ошибся. Может быть, кто-то, возможно, взглянет на это, пожалуйста, и сообщите мне, где я ошибся.

Большое спасибо

1 Ответ

1 голос
/ 11 ноября 2011

Я только что сравнил запрос, который вы используете, с тем, который я использовал для очень похожего приложения, которое я написал.Все точно так же, кроме одинарных кавычек вокруг ваших переменных - center_lat, center_lng, radius

Итак, если предположить, что эти переменные установлены правильно, удаление одинарных кавычек вокруг них должно решить вашу проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...