Я не вижу, что в этом нет. Самый простой sql без формулы Хаверсина работает отлично. Я имею в виду, должно быть, что-то о sql или statments. Я не вижу этого. Некоторые идеи? Спасибо,PHP PDO Ошибка SQL: исключение исключения «PDOException» с сообщением «SQLSTATE [HY093]: недопустимый номер параметра
<?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();
?>
Нет уверен, но я не думаю, вы можете recycle paramters вам нужны уникальные привязки, даже если значение идентично или разрешить эмуляцию: '$ db-> setAttribute (PDO :: ATTR_EMULATE_PREPARES, true)' – Mihai
Как сказал @mihai, вы не можете повторно использовать параметры. На самом деле сообщение об ошибке довольно прямолинейно. – junkfoodjunkie