温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

laravel中collection的作用是什么

发布时间:2021-08-03 11:58:30 来源:亿速云 阅读:671 作者:Leah 栏目:大数据

今天就跟大家聊聊有关laravel中collection的作用是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

pluck

public function getDeductCourse()     {         return TeacherFinanceLogModel::select(['order_id', 'period'])->where('type', 6)             ->get()->pluck('period', 'order_id')->all();     }

group map keyBy

public function getStudentCourseByUids($uids)     {         $studentCourse = $this->studentCourseModel             ->select(['uid', 'grade_type', 'subject', 'period', 'old_period', 'period_total', 'finish_period', 'wait_period', 'total_free_period', 'free_period', 'wait_free_period'])             ->whereIn('uid', $uids)             ->get();         return collect($studentCourse)->groupBy('uid')->map(function ($item) {             return $item->keyBy(function ($value) {                     return sprintf("%s-%s-%s", $value['uid'], $value['grade_type'], $value['subject']);                 })->toArray();         })->toArray();     }

filter

public function getRewardsAndPunishByUid($uids)     {         $rewardPunish = $this->courseRewardsModel             ->select([                 "course.uid",                 "course.grade_type",                 "course.subject",                 "course.course_type",                 "course.period_type",                 "course.course_id",                 "course.tid",                 "course_rewards.s_rewards",                 "course_rewards.t_rewards",                 "course_rewards.s_option_status",                 "course_rewards.t_option_status"             ])             ->leftjoin("course", "course.course_id", "=", "course_rewards.course_id")             ->whereIn('course.uid', $uids)             ->where("course.course_type", 1)             ->get();         return collect($rewardPunish)->filter(function ($item) {             return ($item->s_rewards == 1 || $item->s_rewards == -1) && $item->s_option_status != 1;         })->groupBy('uid')->map(function ($item) {             return [                 'reward_total' => $item->filter(function ($value) {                     return $value->s_rewards == 1;                 })->sum('s_rewards'),                 'punish_total' => abs($item->filter(function ($value) {                     return $value->s_rewards == -1;                 })->sum('s_rewards'))             ];         })->toArray();     }

看完上述内容,你们对laravel中collection的作用是什么有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI