为什么我可以';t在php-mysql中显示我的记录


why i can't display my records in php mysql?

我的数据库中有记录,但无法显示它们。有人能查一下我的密码吗。我只是一个业余的网络开发人员。谢谢你的帮助。

<?php
$groups=mysql_query("SELECT * FROM groups ORDER BY id ASC");
$g_res=mysql_affected_rows();
if($g_res>0)
{
while($row=mysql_fetch_array($groups))
{
    $g_id=$row['id'];
    $g_name=$row['g_name'];
    $members=mysql_query("SELECT * FROM members WHERE group='$g_id'");
    $m_res=mysql_affected_rows();
    if($m_res>0)
    {
        while($row2=mysql_fetch_array($members))
        {
            $m_id=$row2['id'];
            $m_name=$row2['m_name'];
            $m_email=$row2['m_email'];
            echo "<tr><td>$m_name<br/>($g_name)</td><td>$m_email</td></tr>";
        }
    }
    else
    {
    echo "<tr><td colspan=2>Nothing to display</td></tr>";
    }
}
}
else
{
echo "<tr><td colspan=2>Error</td></tr>";
}
?>

用这个代码我得到了else的结果,即Error。如果我从查询中删除WHERE group='$g_id',我的所有记录都会随机显示,但我希望按组显示我的记录(成员)。

您需要使用backticks 来转义MySQL中的保留字,如group

SELECT * FROM members WHERE `group` = '$g_id'
                            ^-----^-------------here

当你加入像这样的数据时,你也可以省去内部循环

select g.id as gid, g.g_name, m.id as mid, m.m_name, m.m_email
from groups g
inner join members m on g.id = m.group
order by g.id asc

这更容易,而且会提高性能,因为您不需要执行很多查询,只需要执行一个查询。

另外,请不要在新代码中使用mysql_*函数。它们不再被维护,并被正式弃用。了解Prepared Statements,然后使用PDO或MySQLi。请参阅本文,快速了解如何做到这一点以及为什么它如此重要。

像一样尝试

$members=mysql_query("SELECT * FROM members WHERE `group` = '".$g_id."');

或简称

$members=mysql_query("SELECT * FROM members WHERE `group` = '$g_id'");

您必须连接变量。试试这个:

$members=mysql_query("SELECT * FROM members WHERE `group`='".$g_id."'");

echo "<tr><td>".$m_name."<br/>(".$g_name.")</td><td>".$m_email."</td></tr>";