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 模电中二极管,三极管和电容的应用
  • ¥15 关于模型导入UNITY的.FBX: Check external application preferences.警告。
  • ¥15 气象网格数据与卫星轨道数据如何匹配
  • ¥100 java ee ssm项目 悬赏,感兴趣直接联系我
  • ¥15 微软账户问题不小心注销了好像
  • ¥15 x264库中预测模式字IPM、运动向量差MVD、量化后的DCT系数的位置
  • ¥15 curl 命令调用正常,程序调用报 java.net.ConnectException: connection refused
  • ¥20 关于web前端如何播放二次加密m3u8视频的问题
  • ¥15 使用百度地图api 位置函数报错?
  • ¥15 metamask如何添加TRON自定义网络