我确定我一直盯着这条路太久了,所以索要一条生命线。

我正在从MySQL数据库中提取数据。特别是:

$category[] = "$row->category";
$issue[] = "$row->issue";


我需要浏览数据。总共有6个类别,每个类别可以有任意多个问题。

我想回显每一行的数据,如下所示:

Category 1
Issue 1a
Issue 1b
Issue 1c

Category 2
Issue 2a
Issue 2b

Category 3
Issue 3a
Issue 3b
Issue 3c
Issue 3d
Issue 3e


我可能需要更多的睡眠,但是我似乎无法正确地进行此循环。任何帮助,将不胜感激。

$stmt = $pdo->prepare("SELECT * FROM project INNER JOIN data1 ON project.p_key = data1.p_key_project WHERE data1.p_key_project=? AND data1.archived=? ORDER BY data1.category, data1.updated DESC");
$stmt->execute(array($passed_key,'n'));

while ($row = $stmt->fetchObject()) {
$cust[] = "$row->cust_name";
$p_key[] = "$row->p_key";
$pid[] = "$row->pid";
$account_key[] = "$row->account_key";
$p_key_data1[] = "$row->p_key_data1";
$date[] = "$row->date";
$updated[] = "$row->updated";
$category[] = "$row->category";
$ryg[] = "$row->ryg";
$issue[] = "$row->issue";
$proposed_resolution[] = "$row->proposed_resolution";
$action_items[] = "$row->action_items";
$owner[] = "$row->owner";
$status[] = "$row->status";
}

最佳答案

基于我们一直在谈论的更新的PDO版本:

假设$ issues是您可以处理的问题和类别的多维数组。即$issue[] = "$row->issue, $row->category";

$numOfItems = count($issue); //counts number of times for should be run
   for ($row = 0; $row < $numofItems; $row++) {
     echo $issues[$row][$row] . "</br>";
     $i=0;
     while ($issues[$i][$row] == $issues[$row][$row]) {
      echo $issues[$i][$row] . "</br>";
      $i++;
    } }


这是写意的-但应该可以

下面的旧答案

如果您复制并粘贴数据库模式(或其一部分),这将有助于查看类别和问题之间的关系。没有看到确切的关系,我认为这可能是数据库的结构

因此,让$category[] = "$row->category";填充类别;现在您必须将问题匹配到每个类别。我假设数据库中的一行为每个问题分配了一个类别。即您的数据库看起来像

ID | Category | Issue
1  | Pizza    | Bad
2  | Pizza    | Good


如果是这种情况,那么下面应该可以工作

foreach ($category as $key => $value) {
    $query = mysqli_query($con,"SELECT * FROM project INNER JOIN data1 ON project.p_key = data1.p_key_project WHERE data1.p_key_project=? AND data1.archived=? AND data1.category='$value' ORDER BY data1.category, data1.updated DESC"); //value is the individual category
    echo $value . "</br>";
        while($row = mysqli_fetch_array($query)) {
            echo $row['issue'] . '</br>';
        }
    echo "</br>"; //adds an extra space between categories
}


更新以包括您的特定查询

09-25 16:07
查看更多