0

我已经尝试了一切,但没有任何效果..即使在我编写的其他代码中,它也有效。但由于某种原因,现在不会。

我想加入两个 ID = userID 的表。当我加载页面时,我收到此错误:

警告:mysql_fetch_array():提供的参数不是第 17 行 /home/ynxwleus/domains/mustseenmovies.nl/public_html/films/userinfo.php 中的有效 MySQL 结果资源

有没有人可以帮助我解决这个问题?

代码:

$userID = $_SESSION['s_userID'];
        echo $userID;
        $query = "SELECT userID, userName, userFrontname, userSurname, filmID 
        FROM users
        JOIN seenIt
        ON users.userID = seenIt.userID 
        WHERE (userID ='$userID')";

        $res = mysql_query($query);
                while ($row = mysql_fetch_array($res)) {
                    echo $row['userName'];
                    echo $row['userFrontname'];
                    echo $row['userSurname'];
                    echo $row['filmID'];
                }

提前致谢!

4

3 回答 3

7

您的 where 子句需要一个别名:

    WHERE (users.userID ='$userID')

您的 select 子句还需要 userId 的别名:

    SELECT users.serID, userName, userFrontname, userSurname, filmID

事实上,总是使用别名是一个非常好的主意:

SELECT u.userID, u.userName, u.userFrontname, u.userSurname, si.filmID 
FROM users u join
     seenIt si
    ON u.userID = si.userID 
WHERE u.userID ='$userID'

原始查询有语法错误,因为 SQL 引擎不知道userID引用的是哪个。哦,您在想“这很明显,因为on子句指定值是相同的。” 嗯,人类比 SQL 编译器更聪明,至少在常识方面是这样。

于 2013-02-04T16:59:30.870 回答
2

如果您的查询返回错误,则mysql_query返回 boolean false。您可以使用 打印出此错误mysql_error()

$res = mysql_query($query) or die(mysql_error());

此外,mysql_fetch_row它不适用于布尔值,因此您会收到编译错误。

正如 Gordon 指出的那样,您的查询有错误。

此外,我建议不要再使用mysql,因为它已被弃用。使用MySQLi, 或PDO代替。

于 2013-02-04T17:03:13.340 回答
0
$query = "SELECT userID, userName, userFrontname, userSurname, filmID 
          FROM users
          JOIN seenIt
          WHERE users.userID = seenIt.userID 
          AND  users.userID = ".$userID." ";
于 2014-12-07T10:13:06.637 回答