加入MySQL不起作用

时间:2013-02-04 16:58:04

标签: php mysql join where

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

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

  

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

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

代码:

$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'];
                }

先谢谢!

3 个答案:

答案 0 :(得分: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编译器更聪明,至少在常识方面如此。

答案 1 :(得分:2)

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

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

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

你的查询有错误,正如戈登指出的那样。

此外,我建议不再使用mysql,因为它已被弃用。请改用MySQLiPDO

答案 2 :(得分:0)

$query = "SELECT userID, userName, userFrontname, userSurname, filmID 
          FROM users
          JOIN seenIt
          WHERE users.userID = seenIt.userID 
          AND  users.userID = ".$userID." ";