为什么这个PHP MySQL查询不起作用?

时间:2013-04-30 11:18:18

标签: php mysql

我将此作为我的PHP代码:

$username=($_POST['username']);
$password=($_POST['password']);
$query="SELECT * from 'User' WHERE 'Username'='$username'";
mysql_query($query);

if($rows==0)
{
echo"<p> No rows found</p>";
}

else
{

while($row=mysql_fetch_array($query))
{
echo"rows found";
}

}
mysql_close($conn);

我的表单代码如下:

<form name="login" action="mydamhlogin.php" method="POST">
<p>Username:<input type="text" name="username"></p>
<p>Password<input type="password" name="password"></p>
<p><input type="submit" value="Login"></p>
</form>

我的数据库列名为Username,我正在尝试选择与从表单中获取的$ username匹配的行,但它始终不返回任何行,但这些行肯定在数据库中。

6 个答案:

答案 0 :(得分:9)

你正在使用错误的转义字符,因为单个qoutes使用反引号运算符而不是像这样

$query="SELECT * from `User` WHERE `Username`='$username'";
$result = mysql_query($query);

此处$行是空的,你需要这样做

$rows = mysql_num_rows($result);

然后使用这个$ rows变量来检查它的值。

答案 1 :(得分:3)

使用此

    $query="SELECT * from `User` WHERE `Username`='$username'";

你不应该在表和列周围使用单引号,而是反引号

还添加此

 $rows = mysql_num_rows(mysql_query($query));

在此行之前

     if($rows==0)

编辑:

更改此

   while($row=mysql_fetch_array(mysql_query($query)))
   {
   echo $row['username'];   // this if you want output username , if you want something else just write column name
   }

EDIT2。

这是你的代码

   $username=($_POST['username']);
   $password=($_POST['password']);
   $query=mysql_query("SELECT * from `User` WHERE `Username`='$username'");
   $rows = mysql_num_rows($query);
  if($rows==0)
  {
  echo"<p> No rows found</p>";
 }

 else
{

while($row=mysql_fetch_array($query))
{
echo $row['username'];
}

}
mysql_close($conn);

答案 2 :(得分:0)

这里你错过了许多问题,因为$ rows没有任何值和$ query字符串。 我已修改它使用:

$username=($_POST['username']);
$password=($_POST['password']);
$query="SELECT * from `User` WHERE `Username`='".$username."'";
$exeQuery = mysql_query($query);
$rows = mysql_num_rows($exeQuery)
if($rows==0)
{
echo"<p> No rows found</p>";
} else {

while($row=mysql_fetch_array($exeQuery))
{
echo"rows found";
}

}

答案 3 :(得分:0)

$query="SELECT * from User WHERE Username='$username'";
$result=mysql_query($query);

if($result===false) //instead of $rows
...

编辑:

if( ($result) && (mysql_num_rows($result)>0) )//instead of $rows
...

答案 4 :(得分:-1)

使用此,

$query="SELECT * from User WHERE `Username`='".$username."'";

答案 5 :(得分:-1)

查询的语法错误试试这个

$query="SELECT * from User WHERE `Username`='".$username."'";