1

我有一个列名id, name, category,title和的表news。执行选择查询后,我从表中获取所有必需的数据,但我需要根据它们所属的类别将这些数据分成两个 div。有两个不同的类别,比如 A 和 B。

我需要在一个 div 中显示具有列类别名称 A 的所有数据,并且与类别 B 相同。

$sql= "SELECT id, title ,news ,category FROM news  ";
$query=mysql_query($sql, $ex)or die(mysql_error())  ;
while($row=mysql_fetch_assoc($query)){ 
    $title=$row['title']; 
    if($row['category']==' Latest News'){
        echo $row['title'];
    }
}

我的代码不起作用。任何想法?

4

1 回答 1

1

您可以首先将类别明智的数据分离到单独的数组中。

$cat1 = array();
$cat2 = array();

$sql="SELECT id, title, news, category FROM news";

$query = mysql_query($sql, $ex) or die(mysql_error());

if(mysql_num_rows($query) > 0)
{
    while($row = mysql_fetch_assoc($query))
    { 

        if($row['category'] == 'A')
        {
            $cat['title'] = $row['title'];
            $cat['news'] = $row['news'];
            $cat1[] = $cat;
        }
        else
        {
            $cat['title'] = $row['title'];
            $cat['news'] = $row['news'];
            $cat2[] = $cat;
        }

    }
}

然后您可以使用foreach将数据打印到单独的div

if(count($cat1) > 0)
{
    foreach($cat1 as $category1_data)
    {
    echo "<div class='cat1'>";
    // data of category A
    echo "</div>";
    }
}

if(count($cat2) > 0)
{
    foreach($cat2 as $category2_data)
    {
        echo "<div class='cat2'>";
        // data of category B
        echo "</div>";
    }
}
于 2015-10-04T08:39:32.073 回答