首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用php检索数据类别智能?

如何使用php检索数据类别智能?
EN

Stack Overflow用户
提问于 2018-07-20 13:53:22
回答 1查看 2.5K关注 0票数 2

我有一个IDProduct和三列的products表。

我想取回我的产品类别,就像这样。

Category1

Product1

Product2

Product3

Product4

Category2

Product1

Product2

Product3

Product4

Category3

Product1

Product2

Product3

Product4

我试过这个..。

代码语言:javascript
复制
<?php
require_once('config.php');
$conn = mysqli_connect($servername, $username, $password, $dbname);

$sql = "SELECT * FROM `products` WHERE status = 1";

$result = $conn->query($sql);

if (@$result->num_rows > 0) 
{
    while($row = $result->fetch_assoc())
    {
        $category = $row['category'];
        $name = $row['name'];

        foreach ($row as $category) 
        {
            echo $name."<br/>";
        }
    }
}
?>

但它多次重复每种产品.

请帮帮忙!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-20 14:08:06

您可以尝试循环结果,同时保存最后遇到的类别的记录。见以下代码(未经测试):

代码语言:javascript
复制
<?php
require_once('config.php');
$conn = mysqli_connect($servername, $username, $password, $dbname);

$sql = "SELECT * FROM `products` WHERE status = 1 ORDER BY category ASC, name ASC";

$result = $conn->query($sql);

if (@$result->num_rows > 0) 
{
    $previous_category = ""   // To keep track of the last printed category
    while($row = $result->fetch_assoc())
    {
        $category = $row['category'];
        $name = $row['name'];

        if ($previous_category !== $category) { // If this category has never been printed, we print it
            echo $category."<br/>";
            $previous_category = $category;
        }

        echo $name."<br/>";
    }
}
?>

希望它有帮助:)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51444109

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档