1

我现在对这个问题绝望了,这就是我在这里的原因。我是 PHP 和 mysql 编程的初学者。我在网上搜索了解决方案,但没有成功。我正在做一个项目,什么是汽车维修管理系统。这是我需要的一部分。

我有两张桌子:

repairs (j_id /this is the primary key/, rendszam, javitas, megjegyzes, datum) 
and 
pictures (kep_id /this is the primary key/, j_id /it's from repairs j_id/, kepnev)

我需要在表格中显示一个结果,在这里我可以看到哪些修复在图片表中有图片,但没有冗余,所以我不想要多个彼此相似的修复行,而是一个修复行后面有多个图片列。

我已经做了什么:

<?php
$sql = "SELECT $tbl_name2.j_id, $tbl_name2.rendszam, $tbl_name2.javitas, $tbl_name2.megjegyzes, $tbl_name2.datum, $tbl_name3.kepnev FROM $tbl_name2, $tbl_name3 WHERE $tbl_name2.j_id=$tbl_name3.j_id";

$result = mysql_query($sql) or die(mysql_error());

while ($row = mysql_fetch_array($result)) {
    echo "<tr><td>" . $row[$i] . "</td>";
    echo "<td>" . $row[$i + 1] . "</td>";
    echo "<td>" . $row[$i + 2] . "</td>";
    echo "<td>" . $row[$i + 3] . "</td>";
    echo "<td>" . $row[$i + 4] . "</td>";
    echo "<td>" . $row[$i + 5] . "</td>";
}
?>

这个显示如下信息:

repair id | picture

1    |    fdgdfg.jpg
1    |    fgdfg.jpg
1    |    fghh.jpg
25   |    dfg.jpg
25   |    jkjk.jpg

但我不想有多个修复行,而是一个修复行,后面有多张图片。

我试过这个:

$sql2="SELECT DISTINCT $tbl_name2.j_id, $tbl_name3.kepnev FROM $tbl_name2, $tbl_name3 WHERE $tbl_name2.j_id=$tbl_name3.j_id";

$result2=mysql_query($sql2) or die(mysql_error());

$sql="SELECT $tbl_name2.j_id, $tbl_name2.rendszam, $tbl_name2.javitas, $tbl_name2.megjegyzes, $tbl_name2.datum, $tbl_name3.kepnev FROM $tbl_name2, $tbl_name3 WHERE $tbl_name2.j_id=$tbl_name3.j_id GROUP BY j_id;

$result=mysql_query($sql) or die(mysql_error());

while($row=mysql_fetch_array($result))
{
echo "<tr><td>".$row[$i]."</td>";
echo "<td>".$row[$i+1]."</td>";
echo "<td>".$row[$i+2]."</td>";
echo "<td>".$row[$i+3]."</td>";
echo "<td>".$row[$i+4]."</td>";
echo "<td>".$row[$i+5]."</td>";
while($sor=mysql_fetch_array($result2))
    {
        if($sor['j_id']==$row[$i]){
        echo "<td><a href=kepek/".$sor['kepnev']." target=_blank>".$sor['kepnev']."</a></td>";
        }
    }

}

sql 语句在 $sql 中的 group by 中有所不同,但这个显示结果如下:

 repair id | picture

    1    |    fdgdfg.jpg | fgdfg.jpg | fghh.jpg
    25   |        

所以它只是在第一个修复 id 之后没有继续,没有显示修复 id 25 的修复图片。

我不知道,我怎样才能正确。我需要一个显示如下信息的表格:

repair id | picture

   1    |    fdgdfg.jpg | fgdfg.jpg | fghh.jpg
   25   |    dfg.jpg | jkjk.jpg

你能帮我解决这个问题吗?

4

1 回答 1

1

这听起来很简单,看起来你已经有了一个好的开始。

我过去做过类似的事情,我只是使用一个变量来跟踪当前显示的 ID 和之前显示的 ID。这是一个快速代码示例来概述我的意思。

while($row=mysql_fetch_array($result))
{
    $currentID=$row[$i];
    if ($currentID != $lastID) { 
        echo "</tr><tr><td>".$row[$i]."</td>"; 
    } else {
        echo "<td>".$row[$i]."</td>";   
    }
    $lastID=$row[$i];
}

因此,我们的想法是跟踪最后一个 ID 是什么。在下一行中,如果 ID 相同,只需输出 <td>"variable goes here"</td> 以使其保持在同一列上。如果 ID 更改,请结束该行并使用 </tr><tr>" 创建一个新行。如果您需要更多帮助,请随时发表评论。

于 2012-04-22T22:29:50.683 回答