Php 避免重复值,并在mysql数据库中获取相同行中的其他数据集

Php 避免重复值,并在mysql数据库中获取相同行中的其他数据集,php,mysql,codeigniter,activerecord,Php,Mysql,Codeigniter,Activerecord,我有一个包含多个项目的数据库表。我想在选项卡视图中显示每个项目。因此,我希望获得每个项目名称一次,并获取该项目名称下的其他详细信息。我的桌子如下所示 +-------------+----------+--------------+---------+-------------+ | activity_id | activity | project_name | user_id | description | +-------------+----------+--------------+--

我有一个包含多个项目的数据库表。我想在选项卡视图中显示每个项目。因此,我希望获得每个项目名称一次,并获取该项目名称下的其他详细信息。我的桌子如下所示

+-------------+----------+--------------+---------+-------------+
| activity_id | activity | project_name | user_id | description |
+-------------+----------+--------------+---------+-------------+
|       1     |    A     | New Project  |    5    |   Project   |
|       2     |    B     | New Project  |    5    |   Project   |
|       3     |    C     | New Project  |    5    |   Project   |
|       4     |    D     | New Project  |    5    |   Project   |
|       5     |    E     | New Project  |    5    |   Project   |
|       6     |    A     | Old Project  |    5    |   New one   |
|       7     |    B     | Old Project  |    5    |   New one   |
|       8     |    C     | Old Project  |    5    |   New one   |
|       9     |    A     | Another One  |    5    |   Test 01   |
|      10     |    B     | Another One  |    5    |   Test 01   |
|      11     |    C     | Another One  |    5    |   Test 01   |
|      13     |    D     | Another One  |    5    |   Test 01   |
+-------------+----------+--------------+---------+-------------+
有没有一种方法可以像下面的数组一样得到这个表

['New Project'] =>
      [0] =>
          ['activity_Id']   =>   '1'
          ['activity']      =>   'A'
          ['user_id']       =>   '5'
          ['description']   =>   'project'
      [1] =>
          ['activity_Id']   =>   '2'
          ['activity']      =>   'B'
          ['user_id']       =>   '5'
          ['description']   =>   'Project'

就像副作用一样?

这会起作用:

$stm = $pdo->query('SELECT * FROM tablename');
while( $row = $stm->fetch(PDO::FETCH_ASSOC) )
{
    $info = array(
        'activity_id' => $row['activity_id'],
        'activity' => $row['activity'],
        'user_id' => $row['user_id'],
        'description' => $row['description']
    );
    if( array_key_exists($row['project_name'], $array) && is_array($array[$row['project_name']]) )
    {
        $array[$row['project_name']][] = $info;
    }
    else
    {
        $array[$row['project_name']] = array();
        $array[$row['project_name']][] = $info;
    }
}

两个查询将很容易做到这一点, 第一个查询,根据第一个查询项目名称从第二个查询数据中提取不同的项目名称

查询从表中选择不同的项目名称 在这个结果上进行for循环 查询从表中选择活动\ Id、活动、用户\ Id、说明,其中项目\名称=第一次查询的结果 在这个结果上进行for循环
按您的意愿创建数组

不,抱歉,您无法直接使用active record实现这种嵌套—现在在CI3中称为查询生成器—(但您可能可以通过ORM实现,像CakePHP和Laravel这样的框架都有自己的实现)

唯一的方法是创建一个新数组并迭代从模型中获得的结果数组,以便构建所需的结构


您可以在此处查看有关查询生成器的CI3文档:

Um<代码>分组依据?“我也试过使用DISTINCT.。@Fred ii-我试过DISTINCT。。不起作用。。你能提供如何使用它的方法吗?我正在使用CI框架。。这可能与活动记录有关吗?@Nishanweerasingh他不熟悉CI和活动记录,但如果你能以关联数组或对象的形式获得结果,它应该可以正常工作。