我看不到此sql有什么问题。
没有Haversine公式的最简单的sql可以完美地工作。所以我的意思是关于sql或statments。我看不到
有想法吗
谢谢,

<?php
require_once "connectPDO.php";

// Get parameters from URL
$lat = 55; //$_GET["lat"];
$lng = 3; //$_GET["lng"];
$radius = 18; //$_GET["radius"];

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

//$query = $db->prepare("SELECT id, coursename, lat, lng FROM wp_courses");
$query = $db->prepare("SELECT coursename, lat, lng,
( 3959 * acos( cos( radians(:latitude) ) * cos( radians( lat ) )
* cos( radians( lng ) - radians(:longitude) ) + sin( radians(:latitude) )
* sin( radians( lat ) ) ) ) AS distance FROM wp_courses
HAVING distance < :radius ORDER BY distance LIMIT 0 , 20");
$query->bindParam(':latitude', $lat, PDO::PARAM_STR);
$query->bindParam(':longitude', $lng, PDO::PARAM_STR);
$query->bindParam(':radius', $radius, PDO::PARAM_STR);
$query->execute();

header("Content-type: text/xml");
foreach ($query->fetchAll(PDO::FETCH_ASSOC) as $row) {
    $node = $dom->createElement("marker");
    $newnode = $parnode->appendChild($node);
    $newnode->setAttribute("name", $row['coursename']);
    $newnode->setAttribute("lat", $row['lat']);
    $newnode->setAttribute("lng", $row['lng']);
    $newnode->setAttribute("distance", $row['distance']);
}
echo $dom->saveXML();
?>

最佳答案

您不能在查询中重用相同的参数名称,但是只需像这样更改它们就很简单

$query = $db->prepare("SELECT coursename, lat, lng,
( 3959 * acos( cos( radians(:latitude1) ) * cos( radians( lat ) )
* cos( radians( lng ) - radians(:longitude) ) + sin( radians(:latitude2) )
* sin( radians( lat ) ) ) ) AS distance
FROM wp_courses
HAVING distance < :radius ORDER BY distance LIMIT 0 , 20");

$query->bindParam(':latitude1', $lat, PDO::PARAM_STR);
$query->bindParam(':latitude2', $lat, PDO::PARAM_STR);
$query->bindParam(':longitude', $lng, PDO::PARAM_STR);
$query->bindParam(':radius', $radius, PDO::PARAM_STR);
$query->execute();

关于php - PHP PDO SQL错误:带有消息“SQLSTATE [HY093]”的未捕获异常“PDOException”:无效的参数号,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42176223/

10-11 03:40