0

https://developers.google.com/maps/articles/phpsqlsearch_v3で提供されている PHP、MySQL、および Google マップの例を使用してストア ロケーターを作成しています。

XML ドキュメントの書き込みに問題があります。Querious(DB アプリ) から正常にクエリを実行できますが、mysqli に変更した提供されたスクリプトを実行しようとすると、うまくいきません。私は何も返されていません。DB は、例で提供されているようにセットアップされます。これが私が使用する変更されたPHPです。

PHP

<?php
require_once('../includes/connection.php');
require_once('../includes/function.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);

// 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",
  mysqli_real_escape_string($mysqli , $center_lat),
  mysqli_real_escape_string($mysqli , $center_lng),
  mysqli_real_escape_string($mysqli , $center_lat),
  mysqli_real_escape_string($mysqli , $radius));
$result = mysqli_query($mysqli, $query);
$result = mysqli_query($mysqli, $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()
?>

接続が成功し、機能にエラーがないことがわかっています。これについての洞察をありがとう。

4

1 に答える 1

2

「エラーフリー」についてはよくわかりません:)

mysql_fetch_assoc()関数 (非推奨のmysql_*拡張機能の一部) をで使用していますがmysqli、これには互換性がありません。このメソッド呼び出しの@前に、連想配列としてのデータの不適切なフェッチから通常見られるエラーが隠されています。

で連想配列を取得する場合はmysqli、次を使用する必要があります。

$array = $result->fetch_assoc();

http://php.net/manual/en/mysqli-result.fetch-assoc.php

http://us3.php.net/manual/en/language.operators.errorcontrol.php

于 2012-11-05T04:40:52.747 に答える