0

我在显示数据时遇到问题。我有以下数据

filter_name        filter_value
Hard Drize Size    16GB
Hard Drize Size    32GB
Screen Size        7''
Screen Size        8''

我想像这样呈现它。

Hard Drize Size
16GB
32GB

Screen Size
7''
8''

我想要在我的 php 代码中检查 filter_name 是否在 $temp 数组中,如果不是,则将其添加到 $temp 数组中,这样就不会导致重复条目。我现在遇到的问题是,当我在循环中使用相同的数据进行第二次 foreach 时,我没有得到任何数据,而且我的 sql 是正确的。所以我不知道如何输出这些值。对于第二个 foreach,它只打印出第一个 $filter_name["filter_name"] 等等。

php:

if($stmt->rowCount() > 0) 
{
    $filters = "<div class=\"filters\">         
    <div class=\"apply-filters\">Filters</div>";
    $temp = array();        
    $stmt->fetch(PDO::FETCH_ASSOC);

    foreach($stmt as $filter_name)
    {
        if(!in_array($filter_name["filter_name"], $temp)) 
        {
            $temp[] = $filter_name["filter_name"];
            $filters .= "<div class=\"filter-header\">".$filter_name["filter_name"]."</div>";
            //second loop here doesn't work with the same data.
            // test if filter_name["filter_name"] == second loop second_loop["filter_name"]
            // ten write out second_loop["filter_value"] e.g.
            foreach($stmt as $filter_value)
            {
                if($filter_name["filter_name"] == $filter_value["filter_name"])
                {
                    $filters .= $filter_value["filter_value"] ."<br />";
                }                  
            }

        }               
    }
    $filters .= "</div>";   
}
4

5 回答 5

2

$stmt首先,在第一个和第二个foreach之前做一个 var_dump来查看它的形式。也许它的格式不符合您的想法?

为什么不循环一次 $stmt 并在该循环中 print $stmt['filter_name']and $stmt['filter_value']?现在,您$stmt为第一次的每次迭代循环一个“额外”时间foreach。相反,只需做一个foreach($stmt as $filter)and $filter,作为一个关联数组,每个条目都应该包含filter_nameand filter_value

然后,您可以将实际打印移到 之外,foreach并且只在循环中构造您的数组,看起来应该像

array("Hard Drive Size" => array("16GB", "32GB"), "Screen Size" => array("7''", "8''"));

然后你可以使用遍历该数据结构

foreach($myArray as $filter_name => $filter_values)
{
  // Print filter name header
  foreach($filter_values as $filter_value)
  {
    // print each value of the specific filter
  }
}

要构建呈现的结构,您可以执行类似的操作

...

    $filters = array();

    foreach($stmt->fetchAll(PDO::FETCH_ASSOC) as $filter)
    {
      $filters[$filter['filter_name']][] = $filter['filter_value'];     
    }

...

然后迭代$filters结构并打印它。

更新:

从您的 var_dump$stmt很明显,这$stmt不是您的结果集。您应该将结果分配$stmt->fetch给某事。喜欢$result = $stmt->fetch(PDO::FETCH_ASSOC)然后迭代$result

查看

http://php.net/manual/en/pdostatement.fetch.php

http://php.net/manual/en/pdostatement.fetchall.php

于 2013-04-22T06:19:37.047 回答
1

我稍微修改了您的代码以满足您的需求:

$temp = array();
foreach($stmt as $filter_name)
{
    if(!in_array($filter_name["filter_name"], $temp)) 
    {
        echo '<b>' . $filter_name['filter_name'] . '</b><br>';
        $temp[] = $filter_name["filter_name"];

        foreach($stmt as $filter_value)
        {
            if($filter_name["filter_name"] == $filter_value["filter_name"])
            {
                echo $filter_value['filter_value'] . '<br>';
            }
        }
    }
}

您可以在此处查看工作示例-> http://codepad.viper-7.com/aFD079

于 2013-04-22T06:26:55.670 回答
0
if($stmt->rowCount() > 0) 
{
    $filters = "<div class=\"filters\">         
    <div class=\"apply-filters\">Filters</div>";
    $temp = array();        
    $stmt->fetch(PDO::FETCH_ASSOC);

    foreach($stmt as $filter)
        $temp[$filter['filter_name']][] = $filter['filter_value']; 

    foreach($temp as $filter_name => $filter_values)
    {
        $filters .= "<div class=\"filter-header\">".$filter_name."</div>";
        foreach ($filter_values as $value)
            $filters .= $filter_value."<br />";
    }

    $filters .= "</div>";   
}
于 2013-04-22T06:24:33.597 回答
0

$你之前失踪了filter_value

改变

foreach($stmt as filter_value)

foreach($stmt as $filter_value)

于 2013-04-22T06:09:31.260 回答
0
 $stmt->fetch(PDO::FETCH_ASSOC);

foreach($stmt as $filter_name)

可能是(我不确定)

 $aaa= $stmt->fetch(PDO::FETCH_ASSOC);

foreach($aaa as $filter_name)

并尝试

$rows = $stmt->fetch(PDO::FETCH_ASSOC);
$tmp_name='';
$html='';
foreach($rows as $row)
{
    if($row['filter_name'] !=  $tmp_name){
     $html .=$row['filter_name'];
    }
    $html .=$row['filter_value'];

    $tmp_name=$row['filter_name'];
}

回声 $html;

于 2013-04-22T06:13:25.003 回答