您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關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的作用是什么有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。