过去一天我一直在尝试让 mysql 识别我的 PhP 变量,但到目前为止我还没有运气。
编码:
...connect to db...
session_start();
//Calls up Session stored variable
$currentUsr= $_SESSION['username'];
//SQL Query
$sql= 'SELECT Users.Username, books.* FROM Users
INNER JOIN UserLinkBooks lb
ON Users.Username = lb.Username
INNER JOIN Books
ON lb.bkTitle = books.Title
WHERE Users.Username = "$currentUsr"';
$result=mysqli_query($conn,$sql);
//Error Check
if (!$result) {
printf("Error: %s\n", mysqli_error($conn));
exit();}
//display row
while($row=mysqli_fetch_array($result)){
echo "<strong>".$row['Title']."</strong>".$row['Description']."</br>";}
我的问题是 $currentUsr 没有正确调用传递的用户名。对其进行错误检查后,它似乎是空的。
我不明白的是,当我使用代码时:
$sql = "SELECT * FROM Users WHERE `Username`='$currentUsr'";
该变量已处理并且工作正常,完美地调用了书名和描述。另外,如果我手动输入: WHERE Users.UserName = "Bill"'; 它工作正常。
我从各种尝试中得到的其他一些错误是:
WHERE Users.UserName = '.'$currentUsr';
Error: Unknown column '$currentUsr' in 'where clause'
或者
WHERE Users.UserName = '.$currentUsr;
Error: Unknown column 'Bill' in 'where clause'
任何帮助将不胜感激。谢谢