0

我正在运行一个脚本来更新 MySQL 表,并且我一直在回显更新语句以帮助解决更新语句不起作用的原因。当我将 mysql 更新的回显查询复制并粘贴到 phpmyadmin 的 SQL 菜单中时,它运行良好,但是当我运行脚本时,更新查询不执行。我知道我已成功连接到数据库。有谁知道为什么更新语句复制并粘贴到 phpmyadmin 的 sql 选项卡中的回显版本会成功执行,而不是应该在回显语句之前的行执行的实际查询?这是我的php:

<!DOCTYPE html>
<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
<title>Untitled 1</title>
</head>
<body>
<?php
$user = 'tunemashercom';
$pass = 'password';
$host = 'tunemashercom.ipagemysql.com';
$db_name = 'user_library';
@ $db = mysqli_connect($host, $user, $pass, $db_name);  

if (mysqli_connect_errno()) {
    echo 'Error: Could not connect to database.';
    exit;
}

$oldsongs = $_POST['oldsongs'];
$newsongs = $_POST['newsongs'];
$count = count($newsongs);
$count2 = count($oldsongs);
echo "COUNT 1: ".$count." - COUNT 2: ".$count2."<br />";
for($i=0;$i<=$count;$i++){
    $newtitle = $newsongs[$i]["song"];
    echo $newtitle." - ";
    if($newtitle == ""){
        echo "NO NEW TAGS<br />";
    }
    else{
        $title = $oldsongs[$i]["title"];
        echo $title."<br />";
        $artist = $oldsongs[$i]["artist"];
        $album = $oldsongs[$i]["album"];
        $newartist = $newsongs[$i]["artist"];
        $newalbum = $newsongs[$i]["album"];
        $mbid = $newsongs[$i]["mbid"];          
        $insert = "UPDATE collection SET song='".$newtitle."', artist='".$newartist."', album='".$newalbum."', gille_id='".$mbid."' WHERE song='".$title."' AND artist='".$artist."' AND album='".$album."'";
        $results = $db->query($insert);         
        echo $insert."<br />";      
    }
}

mysqli_close($db);

?>
</body>
</html>
4

3 回答 3

0

如果没有看到错误,很难知道问题出在哪里,但是,根据我的个人经验,当我在 UPDATE 查询中发生这种情况时,总是因为我用引号包裹了一个 ID。

希望这会有所帮助。

于 2013-02-08T01:37:03.467 回答
0

问题可能与引号有关。在键入单引号时是 'sumthng' 但在执行更新查询时,我们需要sumthng. 我希望这行得通。我遇到了同样的问题,使用直接从 phpmyadmi 复制的引号解决了这个问题。

于 2016-07-01T05:34:24.833 回答
-1

确保 phpmyAdmin 是与 php 代码相同的数据库,因此“tunemashercom.ipagemysql.com”

检查以确保您使用 phpmyAdmin 的数据库(运行回显查询)与您使用 PHP 代码连接的数据库相同。

例如,您正在从本地计算机连接到 phpmyAdmin,并且您的 php 代码正在连接到托管服务器上的数据库。

于 2015-11-14T12:03:20.073 回答