javascript - 无法更新 MySQL 数据库中的单元格?
问题描述
我有一个用于游戏的谷歌地图网络应用程序,用户将单击谷歌地图标记,在弹出的窗口中进行选择并单击提交。它使用 AJAX 使用用户选择的信息更新数据库。数据库预先填充了标记的名称和 GPS 坐标,它们已加载。在通过 XML 加载时也会相应地放置标记。
提交时,我无法使用用户选择的信息更新我的数据库中名为quest的一行。目前,用户可以选择一个标记并提交一个任务,但它根本不会更新数据库。我不确定要使用的正确 WHERE 语句。这是我当前的 SQL 语句,我正在尝试更新名为quest的行。
mysqli_query($con, "UPDATE markers SET quest= '$questName' WHERE markerName = '$markerName'");
这是我在 myMap 函数中的 downloadURL 函数
downloadUrl("call2.php", function(data) {
var xml = data.responseXML;
var markers = xml.documentElement.getElementsByTagName("marker");
for (var i = 0; i < markers.length; i++) {
var name = markers[i].getAttribute("markerName");
// var address = markers[i].getAttribute("address");
var type = markers[i].getAttribute("type");
var point = new google.maps.LatLng(
parseFloat(markers[i].getAttribute("lat")),
parseFloat(markers[i].getAttribute("longg")));
var icon = customLabel[type] || {};
var marker = new google.maps.Marker({
map: map,
position: point,
icon: icon.icon,
shadow: icon.shadow
});
bindInfoWindow(marker, map, infoWindow, html);
}
});
这就是按下提交按钮时发生的情况。
if (document.getElementById("questType").value ==
"quest1") { //if quest1 is selected upon submission
alert("quest1");
var markerName;
var questName = "Quest 1";
xmlhttp = new XMLHttpRequest(); //Creating the
XMLHttpRequest object
xmlhttp.open("GET", "ajax.php?questName=" + questName
+ "&markerName=" + markerName, true); //Specifying the type of request to the server
xmlhttp.send(); //Sending the request to the server
这是我相关的ajax.php。
<?php
include("connect.php");
require("call.php");
if (mysqli_connect_errno()) {
echo "Failed to connect to MySQL: " .
mysqli_connect_error();
} else {
}
$markerName = mysqli_real_escape_string($con,
$_GET['markerName']);
$questName = mysqli_real_escape_string($con,$_GET['questName']);
$lat = mysqli_real_escape_string($con, $_GET['lat']);
$longg = mysqli_real_escape_string($con, $_GET['longg']);
mysqli_query($con, "UPDATE markers SET quest=
'$questName' WHERE markerName = '$markerName'");
mysqli_close($con);
这也是我的相关通话文件。
$dom = new DOMDocument("1.0");
$node = $dom->createElement("markers");
$parnode = $dom->appendChild($node);
include('connect.php');
$query = "SELECT * FROM markers WHERE 1"; // Select all the rows in the markers table
$result = mysqli_query($con, $query);
if (!$result) {
die('Invalid query: ' . mysqli_error($con));
}
// Iterate through the rows, adding XML nodes for each
while ($row = mysqli_fetch_assoc($result)) {
global $dom, $node, $parnode;
$node = $dom->createElement("marker");
$newnode = $parnode->appendChild($node);
$newnode->setAttribute("markerName",
$row['markerName']);
$newnode->setAttribute("quest", $row['quest']);
$newnode->setAttribute("lat", $row['lat']);
$newnode->setAttribute("longg", $row['longg']);
}
header("Content-type: text/xml");
echo $dom->saveXML();
我没有收到任何错误,但是当我将鼠标悬停在 chrome 上的网络选项卡中的 ajaxphp 上时,它看起来好像正在获取 questName 但 markerName 仍未定义。
解决方案
推荐阅读
- regex - 提取字符串中文件扩展名 (.ps1) 之前的数字
- node.js - 角材料表排序在帖子中不起作用代码
- mysql - 此查询的正确解决方案是什么
- c++ - 为对象指针实现复制构造函数和运算符的正确方法是什么
- machine-learning - Google Colab:即使在运行时断开连接后,我们还能恢复所有数据吗?
- sql - 查询以计算基于季度的平均解决时间
- android - 使用 FusedLocationProvider 时出现 InvocationTargetException
- firebase - 在 Firebase Cloud Function 中读取数据时遇到问题
- node.js - 使用 ws WebSocket 进行身份验证
- asp.net-mvc - SignalR:在 2 个相同的数据库代码之间聊天