doushe8577 2017-07-28 15:11
浏览 64
已采纳

foreach循环和一个来自sql的多个值的键

I have problem to make one array with key ( class_id ) and in this key a lot of users_ids. I have function where $ids is an simple array with numbers. I'm trying to have sth like this:

array => 
   1 (class_id) =>
     0=> 'user_id'
     1=> 'user_id',
   2 (class_id) =>
     0=> 'user_id'
     1=> 'user_id'

Now I'm returning this ( only just with one user_id where there should be more:

array => 
   1=> 'user_id'
   2=> 'user_id'

static function getUsersIdsByClassIds($ids)
{
    $userIds = [];

    foreach($ids as $classId) {

        $object = self::select('user_id')
            ->where('class_id', $classId)
            ->get();

        foreach($object as $sth){
            $userIds[$classId]=$sth->user_id;
        }
    }

    return $userIds;
}

I cant fix it to do this structure I want.

  • 写回答

1条回答 默认 最新

  • duan0708676887 2017-07-28 15:17
    关注

    in here

    foreach($object as $sth){
       $userIds[$classId] = $sth->user_id;
    }
    

    you overwrite the value on each iteration. But you actually want to add a new entry:

    foreach($object as $sth){
                    // here it is
       $userIds[$classId][] = $sth->user_id;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了