我已经尝试了一切,但没有任何作用..即使在我写的其他代码中,也可以。但由于某种原因,它现在不会。
我想加入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'];
}
先谢谢!
答案 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
,因为它已被弃用。请改用MySQLi
或PDO
。
答案 2 :(得分:0)
$query = "SELECT userID, userName, userFrontname, userSurname, filmID
FROM users
JOIN seenIt
WHERE users.userID = seenIt.userID
AND users.userID = ".$userID." ";